亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

分布式開發(fā)醫(yī)療掛號系統(tǒng)數(shù)據(jù)字典模塊前后端實現(xiàn)

 更新時間:2022年04月24日 17:32:07   作者:Hudie.  
這篇文章主要為大家介紹了分布式開發(fā)醫(yī)療掛號系統(tǒng)數(shù)據(jù)字典模塊前后端實現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

數(shù)據(jù)字典模塊

數(shù)據(jù)字典可以管理系統(tǒng)常用的分類數(shù)據(jù)或 固定數(shù)據(jù),例如:省市區(qū)三級聯(lián)動數(shù)據(jù)、民族數(shù)據(jù)、行業(yè)數(shù)據(jù)、學歷數(shù)據(jù)等。由于我們的 分布式醫(yī)療掛號系統(tǒng) 大量使用這種數(shù)據(jù),所有我們要做一個數(shù)據(jù)管理,方便管理系統(tǒng)數(shù)據(jù),并且在一般的系統(tǒng)中基本都會做數(shù)據(jù)管理。

數(shù)據(jù)字典主要功能:使系統(tǒng)中的各項數(shù)據(jù)變的更加的嚴格,這樣有利于降低因為數(shù)據(jù)問題而導(dǎo)致的bug。

一、后端接口

1.數(shù)據(jù)庫表設(shè)計

數(shù)據(jù)字典的數(shù)據(jù)庫表字段和對應(yīng)的實體類的屬性應(yīng)該是一一對應(yīng)的,但要注意下面兩個地方:

添加上@TableLogic表示為邏輯刪除,后續(xù)刪除操作會自動變?yōu)樾薷牟僮?。為了實現(xiàn)頁面上單擊展開子節(jié)點的功能,額外使用@TableField(exist = false)加入ha’s’Children屬性。

數(shù)據(jù)庫表和實體類

2.編寫三層調(diào)用

根據(jù)下圖總結(jié)的三層調(diào)用關(guān)系,我們需要分別編寫好Controlller層、Service層、Mapper層的代碼。

三層調(diào)用的關(guān)系

Controller層

通過url:/admin/cmn/dict/findChildData/{id} 訪問資源到達控制層后,控制層調(diào)用服務(wù)層的findChildData(Long id)方法。

@Api(tags = "數(shù)據(jù)字典接口")
@RestController
@RequestMapping("/admin/cmn/dict")
@CrossOrigin
public class DictController {
    @Autowired
    private DictService dictService;
    @ApiOperation(value = "根據(jù)id查詢子數(shù)據(jù)列表")
    @GetMapping("findChildData/{id}")
    public Result findChildData(@PathVariable Long id) {
        List<Dict> list = dictService.findChildData(id);
        return Result.ok(list);
    }
}

Service層

在服務(wù)層根據(jù)id查詢子數(shù)據(jù)列表,調(diào)用數(shù)據(jù)層的查詢方法查到子數(shù)據(jù)集合后,將集合遍歷,遍歷過程中為每條記錄的hasChildren屬性賦值。具體業(yè)務(wù)邏輯詳見下面的代碼:

Service接口繼承IService<T>接口:

public interface DictService extends IService<Dict> {
    /**
     * 根據(jù)id查詢子數(shù)據(jù)列表
     * @param id
     * @return list
     */
    List<Dict> findChildData(Long id);
}

Service實現(xiàn)類繼承ServiceImpl<TMapper, T>類:

@Service
public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements DictService {
    /**
     * 根據(jù)id查詢子數(shù)據(jù)列表
     * @param id
     * @return list
     */
    @Override
    public List<Dict> findChildData(Long id) {
        QueryWrapper<Dict> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("parent_id", id);
        List<Dict> dictList = baseMapper.selectList(queryWrapper);
        for (Dict dict : dictList) {
            // 得到每一條記錄的id值
            Long dictId = dict.getId();
            // 調(diào)用hasChildren方法判斷是否包含子節(jié)點
            boolean flag = this.hasChildren(dictId);
            // 為每條記錄設(shè)置hasChildren屬性
            dict.setHasChildren(flag);
        }
        return dictList;
    }
    /**
     * 判斷id下面是否有子結(jié)點
     * @param id
     * @return true:有子結(jié)點,false:無子結(jié)點
     */
    private boolean hasChildren(Long id) {
        QueryWrapper<Dict> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("parent_id", id);
        Integer count = baseMapper.selectCount(queryWrapper);
        return count > 0;
    }
}

Mapper層

Mapper接口繼承了BaseMapper<T>接口。由于服務(wù)層調(diào)用的方法是BaseMapper自帶的方法,所以在數(shù)據(jù)層,我們并沒有給出具體的方法。

public interface DictMapper extends BaseMapper<Dict> {
}

由于在數(shù)據(jù)字典模塊中配置類、配置文件不是我們主要研究的內(nèi)容,所以這里不再給出,具體可參考github倉庫代碼。至此,數(shù)據(jù)字典模塊的后端接口已經(jīng)完成:

數(shù)據(jù)字典模塊后端接口

二、前端頁面

1.添加路由

由于數(shù)據(jù)管理中的數(shù)據(jù)字典是一個全新的頁面,我們可以將數(shù)據(jù)字典的路由設(shè)置為/cmn/list,路由到/cmn/list后,會跳轉(zhuǎn)到/views/dict/list.js資源。

  // 數(shù)據(jù)字典路由
  {
    path: '/cmn',
    component: Layout,
    redirect: '/cmn/list',
    name: '數(shù)據(jù)管理',
    meta: { title: '數(shù)據(jù)管理', icon: 'example' },
    // 如果只有一級會僅顯示子按鈕,添加alwaysShow=true 可以使父按鈕也顯示
    alwaysShow:true,
    children: [
      {
        path: 'list',
        name: '數(shù)據(jù)字典',
        component: () => import('@/views/dict/list'),
        meta: { title: '數(shù)據(jù)字典', icon: 'table' }
      }
    ]
  },

2.添加跳轉(zhuǎn)頁面

路由后,跳轉(zhuǎn)到/views/dict/list.js頁面,下面給出此頁面的邏輯片段代碼和其調(diào)用的api接口代碼:

在跳轉(zhuǎn)到的頁面獲取后端數(shù)據(jù)

3.頁面表格渲染

表格渲染我們使用elementUI提供開發(fā)文檔:樹形數(shù)據(jù)與懶加載表格組件。

修改后的代碼如下:

:data=“list”

查出來的數(shù)據(jù)。

:load=“getChildrens”

加載getChildrens方法。

:tree-props="{ children: ‘children’, hasChildren: ‘hasChildren’ }"

樹的屬性值,通過屬性值來判斷hasChildren中的值是true還是false。

<template>
  <div class="app-container">
    <el-table
      :data="list"
      :load="getChildrens"
      :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
      style="width: 100%"
      row-key="id"
      border
      lazy>
      <el-table-column label="名稱" width="230" align="left">
        <template slot-scope="scope">
          <span>{{ scope.row.name }}</span>
        </template>
      </el-table-column>
      <el-table-column label="編碼" width="220">
        <template slot-scope="{ row }">
          {{ row.dictCode }}
        </template>
      </el-table-column>
      <el-table-column label="值" width="230" align="left">
        <template slot-scope="scope">
          <span>{{ scope.row.value }}</span>
        </template>
      </el-table-column>
      <el-table-column label="創(chuàng)建時間" align="center">
        <template slot-scope="scope">
          <span>{{ scope.row.createTime }}</span>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

三、標準Debug流程

目前數(shù)據(jù)字典模塊的前后端已經(jīng)開發(fā)完成了,但是此刻如果允許程序,頁面并不會加載到后端傳過來的數(shù)據(jù)。因為不同的訪問請求訪問到不同的服務(wù)器中,我們?yōu)閿?shù)據(jù)字典模塊設(shè)置端口是8202,而前端config/dev.env.js中,配置的是之前醫(yī)院設(shè)置模塊中的8201端口。

我們可以加入Nginx暫時解決,后期也會加入路由來替換掉Nginx,不過僅為了展示效果,這里簡單的將前端 config/dev.env.js 中的端口改為和數(shù)據(jù)字典模塊8202統(tǒng)一的端口。關(guān)于Nginx和添加統(tǒng)一路由會在后續(xù)的文章中進行介紹。

至此,數(shù)據(jù)字典模塊的初步功能就已經(jīng)實現(xiàn)完成了。

以上就是分布式開發(fā)醫(yī)療掛號系統(tǒng)數(shù)據(jù)字典模塊前后端實現(xiàn)的詳細內(nèi)容,更多關(guān)于分布式醫(yī)療掛號系統(tǒng)數(shù)據(jù)字典模塊前后端的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • java xml轉(zhuǎn)為json的n種方法

    java xml轉(zhuǎn)為json的n種方法

    本文給大家分享java xml轉(zhuǎn)為json的兩種方法,每種方法通過實例代碼給大家介紹的非常詳細,小編感覺第一種方法要比第二種方法好些,具體實現(xiàn)代碼跟隨小編一起看看吧
    2021-08-08
  • Java 實戰(zhàn)項目錘煉之樸素風格個人博客系統(tǒng)的實現(xiàn)流程

    Java 實戰(zhàn)項目錘煉之樸素風格個人博客系統(tǒng)的實現(xiàn)流程

    讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用Java+vue+Springboot+ssm+mysql+maven+redis實現(xiàn)一個樸素風格的個人博客系統(tǒng),大家可以在過程中查缺補漏,提升水平
    2021-11-11
  • Java Math.round函數(shù)詳解

    Java Math.round函數(shù)詳解

    這篇文章主要介紹了Java Math.round函數(shù)詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Java中notify和notifyAll的區(qū)別及何時使用

    Java中notify和notifyAll的區(qū)別及何時使用

    本文主要介紹了Java中notify和notifyAll的區(qū)別及何時使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Java Map集合使用方法全面梳理

    Java Map集合使用方法全面梳理

    Map是一種依照鍵(key)存儲元素的容器,鍵(key)很像下標,在List中下標是整數(shù)。在Map中鍵(key)可以使任意類型的對象。Map中不能有重復(fù)的鍵(Key),每個鍵(key)都有一個對應(yīng)的值(value)。一個鍵(key)和它對應(yīng)的值構(gòu)成map集合中的一個元素
    2022-04-04
  • java仿windows記事本功能完整版

    java仿windows記事本功能完整版

    這篇文章主要為大家詳細介紹了java仿windows記事本功能完整版,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • java對接支付寶支付項目的實戰(zhàn)記錄

    java對接支付寶支付項目的實戰(zhàn)記錄

    最近公司有一個需求是接入第三方支付(微信&支付寶),我接到了支付寶支付,所以下面這篇文章主要給大家介紹了關(guān)于java對接支付寶支付項目的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • springboot配置多數(shù)據(jù)源并集成Druid和mybatis的操作

    springboot配置多數(shù)據(jù)源并集成Druid和mybatis的操作

    這篇文章主要介紹了springboot配置多數(shù)據(jù)源并集成Druid和mybatis的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • SpringBoot集成Swagger2生成接口文檔的方法示例

    SpringBoot集成Swagger2生成接口文檔的方法示例

    我們提供Restful接口的時候,API文檔是尤為的重要,它承載著對接口的定義,描述等,本文主要介紹了SpringBoot集成Swagger2生成接口文檔的方法示例,需要的朋友們下面隨著小編來一起學習學習吧
    2018-12-12
  • Jmeter跨線程組傳值調(diào)用實現(xiàn)圖解

    Jmeter跨線程組傳值調(diào)用實現(xiàn)圖解

    這篇文章主要介紹了Jmeter跨線程組傳值調(diào)用實現(xiàn)圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07

最新評論