您好,登錄后才能下訂單哦!
mybatis-plus中Service和Mapper的區別?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
在后端開發過程中,如果有用到mybatis-plus,肯定會發現在其內部存在著兩種數據庫操作接口,Iservice和BaseMapper,如果只是用增刪改查會發現兩者的功能是一致的,除了方法名稱有所不同,其他的基本相似。對此,我頗為好奇,便打開兩個接口的源碼進行對比。
先演示一下基本開發中的繼承關系,手動創建的Service繼承于ServiceImpl,并加載自己創建的Mapper
@Service public class RestDeptService extends ServiceImpl<RestDeptMapper, RestDept> { @Resource private RestDeptMapper restDeptMapper; } public interface RestDeptMapper extends BaseMapper<RestDept> { }
如上,就是一般開發的基本模版代碼,足以滿足各種需求功能,但點開源碼時,便進入新世界的大門。先看一下繼承結構
這樣看,是不是很神奇,我們繼承的ServiceImpl依舊實現了BaseMapper接口和Iservice接口,這就感覺有點啰嗦了,明明我們單獨寫了RestDeptMapper,并且繼承了BaseMapper,現在ServiceImpl還是實現了BaseMapper,那我直接一個Service用下來不就行了,創建兩套類,功能相似,還容易混亂,代碼結構冗余。
本著“存在即合理”的理念,我們對比一下兩個接口的方法。
果然,Service簡直是BaseMapper的大擴充,不但包含了所有基本方法,還加入了很多批處理功能,我們可以看一下官網對這兩種接口的說明。
官網鏈接:https://mp.baomidou.com/guide/crud-interface.html
Service CRUD 接口
說明:
get 查詢單行
remove 刪除
list 查詢集合
page 分頁
前綴命名方式區分 Mapper
層避免混淆,T
為任意實體對象IBaseService
繼承 Mybatis-Plus
提供的基類Wrapper
為 條件構造器Mapper CRUD 接口
說明:
Mybatis-Plus
啟動時自動解析實體表關系映射轉換為 Mybatis
內部對象注入容器T
為任意實體對象Serializable
為任意類型主鍵 Mybatis-Plus
不推薦使用復合主鍵約定每一張表都有自己的唯一 id
主鍵Wrapper
為 條件構造器最后本文還是比較水的,只是簡單的看了一下結構而已,沒有太多的深入,總結一下,以我平時粘貼復制的經驗來看,Service雖然加入了數據庫的操作,但還是以業務功能為主,而更加復雜的SQL查詢,還是要靠Mapper對應的XML文件里去編寫SQL語句。
關于mybatis-plus中Service和Mapper的區別問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。