激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - java開發(fā)MVC三層架構(gòu)上再加一層Manager層原理詳解

java開發(fā)MVC三層架構(gòu)上再加一層Manager層原理詳解

2022-03-03 00:42飄渺Jam Java教程

這篇文章主要為大家介紹了MVC三層架構(gòu)中再加一層Manager層原理的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步

MVC三層架構(gòu)

我們在剛剛成為程序員的時(shí)候,就會被前輩們 “教育” 說系統(tǒng)的設(shè)計(jì)要遵循 MVC(Model-View-Controller)架構(gòu)。它將整體的系統(tǒng)分成了 Model(模型),View(視圖)和 Controller(控制器)三個(gè)層次,也就是將用戶視圖和業(yè)務(wù)處理隔離開,并且通過控制器連接起來,很好地實(shí)現(xiàn)了表現(xiàn)和邏輯的解耦,是一種標(biāo)準(zhǔn)的軟件分層架構(gòu)。

java開發(fā)MVC三層架構(gòu)上再加一層Manager層原理詳解

MVC分層架構(gòu)是架構(gòu)上最簡單的一種分層方式。為了遵循這種分層架構(gòu)我們在構(gòu)建項(xiàng)目時(shí)往往會建立這樣三個(gè)目錄:controller、service 和 dao,它們分別對應(yīng)了表現(xiàn)層、邏輯層還有數(shù)據(jù)訪問層。

java開發(fā)MVC三層架構(gòu)上再加一層Manager層原理詳解

每層的作用如下:

Controller層:主要是對訪問控制進(jìn)行轉(zhuǎn)發(fā),各類基本參數(shù)校驗(yàn),或者不復(fù)用的業(yè)務(wù)簡單處理。

Service層:主要是處理業(yè)務(wù)邏輯和事務(wù)

Dao層:負(fù)責(zé)與底層數(shù)據(jù)庫MySQL,Oracle等進(jìn)行數(shù)據(jù)交互

可是隨著我們的業(yè)務(wù)邏輯越來復(fù)雜,代碼寫的越來越多,這種簡單的三層架構(gòu)的問題也越來越明顯。

 

MVC架構(gòu)弊端

傳統(tǒng)的MVC分層有以下幾個(gè)很明顯的問題:

Service層代碼臃腫

Service層很容易出現(xiàn)大事務(wù),事務(wù)嵌套,導(dǎo)致問題很多,而且極難排查

dao層參雜業(yè)務(wù)邏輯

dao層sql語句復(fù)雜,關(guān)聯(lián)查詢比較多

為了解決這個(gè)問題,我們參考《alibaba java開發(fā)手冊》,在Service層之下再獨(dú)立出一個(gè)通用業(yè)務(wù)處理層(Manager層)

java開發(fā)MVC三層架構(gòu)上再加一層Manager層原理詳解

在這個(gè)分層架構(gòu)中主要增加了 Manager 層,它與 Service 層的關(guān)系是:Manager 層提供原子的服務(wù)接口,Service 層負(fù)責(zé)依據(jù)業(yè)務(wù)邏輯來編排原子接口。

 

Manager層的特征

在《alibaba java開發(fā)手冊》中是這樣描述Manager層的:

Manager 層:通用業(yè)務(wù)處理層,它有如下特征:

對第三方平臺封裝的層,預(yù)處理返回結(jié)果及轉(zhuǎn)化異常信息,適配上層接口;對 Service 層通用能力的下沉,如緩存方案、中間件通用處理;與 DAO 層交互,對多個(gè) DAO 的組合復(fù)用。

在實(shí)際開發(fā)中我們可以這樣使用Manager層

復(fù)雜業(yè)務(wù),service提供數(shù)據(jù)給Manager層,負(fù)責(zé)業(yè)務(wù)編排,然后把事務(wù)下沉到Manager層,Manager層不允許相互調(diào)用,不會出現(xiàn)事務(wù)嵌套。

專注于不帶業(yè)務(wù)sql語言,也可以在manager層進(jìn)行通用業(yè)務(wù)的dao層封裝。

避免復(fù)雜的join查詢,數(shù)據(jù)庫壓力比java大很多,所以要嚴(yán)格控制好sql,所以可以在manager層進(jìn)行拆分,比如復(fù)雜查詢。

當(dāng)然對于簡單的業(yè)務(wù),可以不使用Manager層。

 

Manager層使用案例

這里我們舉個(gè)例子說明一下Manager層的使用場景:

假設(shè)你有一個(gè)用戶系統(tǒng),他有一個(gè)獲取用戶信息的接口,它調(diào)用邏輯Service層的 getUser 方法,getUser方法又和 User DB 交互獲取數(shù)據(jù)。如下圖左邊展示部分。

這時(shí),產(chǎn)品提出一個(gè)需求,在 APP 中展示用戶信息的時(shí)候,如果用戶不存在,那么要自動給用戶創(chuàng)建一個(gè)用戶。同時(shí),要做一個(gè) HTML5 的頁面,HTML5 頁面要保留之前的邏輯,也就是不需要?jiǎng)?chuàng)建用戶。

java開發(fā)MVC三層架構(gòu)上再加一層Manager層原理詳解

此時(shí)按照傳統(tǒng)的三層架構(gòu),邏輯層的邊界就變得不清晰,表現(xiàn)層也承擔(dān)了一部分的業(yè)務(wù)邏輯,因?yàn)槲覀兺鶗诒憩F(xiàn)層Controller中增加業(yè)務(wù)邏輯處理,將獲取用戶和創(chuàng)建用戶接口編排起來。

而添加Manager層以后,Manager 層提供創(chuàng)建用戶和獲取用戶信息的接口,而 Service 層負(fù)責(zé)將這兩個(gè)接口組裝起來。這樣就把原先散布在表現(xiàn)層的業(yè)務(wù)邏輯都統(tǒng)一到了 Service 層,每一層的邊界就非常清晰了。

接下來我們看一段實(shí)際代碼說明一下Service層與Manager層如何進(jìn)行區(qū)分?

@Transactional(rollbackFor = Throwable.class)
public Result<String> upOrDown(Long departmentId, Long swapId) {
// 驗(yàn)證 1
DepartmentEntity departmentEntity = departmentDao.selectById(departmentId);
if (departmentEntity == null) {
  return Result.error("部門xxx不存在");
}
// 驗(yàn)證 2
DepartmentEntity swapEntity = departmentDao.selectById(swapId);
if (swapEntity == null) {
  return Result.error("部門xxx不存在");
}
// 驗(yàn)證 3
Long count = employeeDao.countByDepartmentId(departmentId);
if (count != null && count > 0) {
  return Result.error("員工不存在");
}
// 操作數(shù)據(jù)庫 4
Long departmentSort = departmentEntity.getSort();
departmentEntity.setSort(swapEntity.getSort());
departmentDao.updateById(departmentEntity);
swapEntity.setSort(departmentSort);
departmentDao.updateById(swapEntity);
return Result.OK("success");
}

上面代碼在我們在我們采用三層架構(gòu)時(shí)經(jīng)常會遇到,那么它有什么問題呢?

上面的代碼是典型的長事務(wù)問題(類似的還有調(diào)用第三方接口),前三步都是使用 connection 進(jìn)行驗(yàn)證操作,但是由于方法上有@Transactional 注解,所以這三個(gè)驗(yàn)證都是使用的同一個(gè) connection。

若對于復(fù)雜業(yè)務(wù)、復(fù)雜的驗(yàn)證邏輯,會導(dǎo)致整個(gè)驗(yàn)證過程始終占用該 connection 連接,占用時(shí)間可能會很長,直至方法結(jié)束,connection 才會交還給數(shù)據(jù)庫連接池。

對于復(fù)雜業(yè)務(wù)的不可預(yù)計(jì)的情況,長時(shí)間占用同一個(gè) connection 連接不是好的事情,應(yīng)該盡量縮短占用時(shí)間。

說明:對于@Transactional 注解,當(dāng) spring 遇到該注解時(shí),會自動從數(shù)據(jù)庫連接池中獲取 connection,并開啟事務(wù)然后綁定到 ThreadLocal 上,如果業(yè)務(wù)并沒有進(jìn)入到最終的 操作數(shù)據(jù)庫環(huán)節(jié),那么就沒有必要獲取連接并開啟事務(wù),應(yīng)該直接將 connection 返回給數(shù)據(jù)庫連接池,供其他使用。

所以我們在加入Manager層以后可以這樣寫:

DepartmentService.java 
public Result<String> upOrDown(Long departmentId, Long swapId) {
// 驗(yàn)證 1
DepartmentEntity departmentEntity = departmentDao.selectById(departmentId);
if (departmentEntity == null) {
  return Result.error("部門xxx不存在");
}
// 驗(yàn)證 2
DepartmentEntity swapEntity = departmentDao.selectById(swapId);
if (swapEntity == null) {
  return Result.error("部門xxx不存在");
}
// 驗(yàn)證 3
Long count = employeeDao.countByDepartmentId(departmentId);
if (count != null && count > 0) {
  return Result.error("員工不存在");
}
// 操作數(shù)據(jù)庫 4
departmentManager.upOrDown(departmentSort,swapEntity);
return Result.OK("success");
}
DepartmentManager.java

@Transactional(rollbackFor = Throwable.class)
public void upOrDown(DepartmentEntity departmentEntity ,DepartmentEntity swapEntity){
Long departmentSort = departmentEntity.getSort();
departmentEntity.setSort(swapEntity.getSort());
departmentDao.updateById(departmentEntity);
swapEntity.setSort(departmentSort);
departmentDao.updateById(swapEntity);
}

將數(shù)據(jù)在 service 層準(zhǔn)備好,然后傳遞給 manager 層,由 manager 層添加 @Transactional事務(wù)注解進(jìn)行數(shù)據(jù)庫操作。

以上就是MVC三層架構(gòu)上再加一層Manager層原理詳解的詳細(xì)內(nèi)容,更多關(guān)于MVC架構(gòu)Manager層原理的資料請關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://blog.csdn.net/jianzhang11/article/details/120884260

延伸 · 閱讀

精彩推薦
  • Java教程Java集合框架源碼分析之LinkedHashMap詳解

    Java集合框架源碼分析之LinkedHashMap詳解

    這篇文章主要介紹了Java集合框架源碼分析之LinkedHashMap詳解,內(nèi)容包括了linkedhashmap的簡介和源碼剖析以及關(guān)于LinkedHashMap的源碼總結(jié),內(nèi)容豐富,需要的朋友...

    BridgeGeorge4792021-01-10
  • Java教程java 中ThreadLocal實(shí)例分析

    java 中ThreadLocal實(shí)例分析

    這篇文章主要介紹了java 中ThreadLocal實(shí)例分析的相關(guān)資料,需要的朋友可以參考下...

    jamesjxin4272020-11-17
  • Java教程SpringMVC的ModelAndView傳值方法

    SpringMVC的ModelAndView傳值方法

    今天小編就為大家分享一篇SpringMVC的ModelAndView傳值方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    ODG8722021-05-24
  • Java教程String與XML互轉(zhuǎn)以及從XML取節(jié)點(diǎn)值并修改的方法

    String與XML互轉(zhuǎn)以及從XML取節(jié)點(diǎn)值并修改的方法

    今天小編就為大家分享一篇String與XML互轉(zhuǎn)以及從XML取節(jié)點(diǎn)值并修改的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    浪丶蕩8712021-05-18
  • Java教程spring mvc中的@ModelAttribute注解示例介紹

    spring mvc中的@ModelAttribute注解示例介紹

    在Spring mvc中,注解@ModelAttribute是一個(gè)非常常用的注解,下面這篇文章主要給大家介紹了關(guān)于spring mvc中@ModelAttribute注解的相關(guān)資料,文中通過示例代碼介紹...

    沈子平5182020-12-28
  • Java教程老生常談Java字符串進(jìn)階(必看篇)

    老生常談Java字符串進(jìn)階(必看篇)

    下面小編就為大家?guī)硪黄仙U凧ava字符串進(jìn)階(必看篇)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧...

    腳本之家4542020-11-19
  • Java教程Java開發(fā)神器Lombok使用詳解

    Java開發(fā)神器Lombok使用詳解

    這篇文章主要介紹了Java開發(fā)神器Lombok使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨...

    程序新視界9582021-10-11
  • Java教程Gson解析空字符串發(fā)生異常的處理方法

    Gson解析空字符串發(fā)生異常的處理方法

    最近在一個(gè)項(xiàng)目中遇到一個(gè)問題,當(dāng)面對一些不規(guī)范的json,我們的gson解析經(jīng)常會拋出各種異常導(dǎo)致app崩潰,通過在網(wǎng)上查找資料,找到了原因,這篇文章給大...

    daisy7172020-06-30
主站蜘蛛池模板: 91专区在线观看 | 久久国产精品二区 | 免费一区在线 | 国产日韩在线观看视频 | 日本网站在线看 | 久久97超碰 | 4p一女两男做爰在线观看 | 国产精品一区二区三区99 | 国产精品1区2区在线观看 | 97久久精品一区二区三区观看 | 亚洲免费看片网站 | 黄色特级毛片 | 国产亚色| 欧美精品久久久久久久久老牛影院 | 99激情| 日韩精品中文字幕一区二区三区 | 国产精品免费看 | 国产91精品一区二区麻豆亚洲 | 久久精品a一级国产免视看成人 | 免费毛片观看 | 91福利社在线| 免费网址黄 | 黄色片网站在线免费观看 | 亚州综合网 | 亚洲精品wwww | 日本在线观看视频网站 | 狠狠干夜夜操 | 91短视频在线播放 | 欧美一级免费在线观看 | 一区二区久久 | 久久久久亚洲视频 | 欧美成人一区二区三区电影 | 99精彩视频在线观看 | 可以看逼的视频 | 色域tv | 日本高清电影在线播放 | 国产成年免费视频 | 欧美成人激情 | 欧美成人午夜一区二区三区 | 色污视频在线观看 | 精品国产一区二区三区在线 |