MyBatis執(zhí)行SQL的兩種方式小結(jié)
MyBatis 有兩種執(zhí)行 SQL 語(yǔ)句的方式,如下:
- 通過 SqlSession 發(fā)送 SQL
- 通過 SqlSession 獲取 Mapper 接口,通過 Mapper 接口發(fā)送 SQL
SqlSession發(fā)送SQL
有映射器之后就可以通過 SqlSession 發(fā)送 SQL 了。我們以 getWebsite 這條 SQL 為例看看如何發(fā)送 SQL。
Website website = (Website)sqlSession.selectOne("net.biancheng.mapper.WebsiteMapper.getWebsite",1);
MyBatis 常用的查詢方法有 2 種,分別為 selectOne 和 selectList。
1)selectOne
selectOne 方法表示使用查詢并且只返回一個(gè)對(duì)象,必須指定查詢條件。只能查詢 0 或 1 條記錄,大于 1 條記錄則運(yùn)行錯(cuò)誤。常用格式如下(也有其它重載方法,根據(jù)需要選擇)。
sqlSession.selectOne(String arg0, Object arg1)
2)selectList
selectList 方法表示使用查詢并且返回一個(gè)列表??梢圆樵?0 或 N 條記錄。常用格式如下。
sqlSession.selectOne(String arg0)
也可指定參數(shù)
sqlSession.selectList(String arg0, Object arg1)
以上語(yǔ)法格式中,String 對(duì)象由一個(gè)命名空間加 SQL id 組合而成,它完全定位了一條 SQL,這樣 MyBatis 就會(huì)找到對(duì)應(yīng)的 SQL。Object 對(duì)象為需要傳遞的參數(shù),也就是查詢條件。
selectOne 實(shí)現(xiàn)的 selectList 都可以實(shí)現(xiàn),即 list 中只有一個(gè)對(duì)象。但 selectList 能實(shí)現(xiàn)的,selectOne 不一定能實(shí)現(xiàn)。
Mapper接口發(fā)送 SQL
SqlSession 還可以獲取 Mapper 接口,通過 Mapper 接口發(fā)送 SQL
WebsiteMapper websiteMapper = sqlSession.getMapper(WebsiteMapper.class); Website website = websiteMapper.getWebsite(1);
通過 SqlSession 的 getMapper 方法獲取一個(gè) Mapper 接口,然后就可以調(diào)用它的方法了。因?yàn)?XML 文件或者接口注解定義的 SQL 都可以通過“類的全限定名+方法名”查找,所以 MyBatis 會(huì)啟用對(duì)應(yīng)的 SQL 運(yùn)行,并返回結(jié)果。
區(qū)別
上面分別講解了 MyBatis 兩種發(fā)送 SQL 的方式,一種用 SqlSession 直接發(fā)送,另外一種通過 SqlSession 獲取 Mapper 接口再發(fā)送。筆者建議采用 Mapper 接口發(fā)送 SQL 的方式,理由如下:
- 使用 Mapper 接口編程可以消除 SqlSession 帶來的功能性代碼,提高可讀性,而 SqlSession 發(fā)送 SQL,需要一個(gè) SQL id 去匹配 SQL,比較晦澀難懂。
- 使用 Mapper 接口,類似 websiteMapper.getWebsite(1) 則是完全面向?qū)ο蟮恼Z(yǔ)言,更能體現(xiàn)業(yè)務(wù)的邏輯。
- 使用 websiteMapper.getWebsite(1) 方式,IDE 會(huì)提示錯(cuò)誤和校驗(yàn),而使用 sqlSession.selectOne("getWebsite",1L) 語(yǔ)法,只有在運(yùn)行中才能知道是否會(huì)產(chǎn)生錯(cuò)誤。
目前使用 Mapper 接口編程已成為主流,尤其在 Spring 中運(yùn)用 MyBatis 時(shí),Mapper 接口的使用就更為簡(jiǎn)單
到此這篇關(guān)于MyBatis執(zhí)行SQL的兩種方式小結(jié)的文章就介紹到這了,更多相關(guān)MyBatis執(zhí)行SQL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spring @schedule注解如何動(dòng)態(tài)配置時(shí)間間隔
這篇文章主要介紹了spring @schedule注解如何動(dòng)態(tài)配置時(shí)間間隔,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11java實(shí)現(xiàn)word文檔轉(zhuǎn)pdf并添加水印的方法詳解
這篇文章主要介紹了java實(shí)現(xiàn)word文檔轉(zhuǎn)pdf并添加水印的方法,結(jié)合實(shí)例形式詳細(xì)分析了java word文檔轉(zhuǎn)PDF相關(guān)實(shí)現(xiàn)技巧與操作注意事項(xiàng),需要的朋友可以參考下2019-09-09Mybatis實(shí)現(xiàn)關(guān)聯(lián)關(guān)系映射的方法示例
本文主要介紹了Mybatis實(shí)現(xiàn)關(guān)聯(lián)關(guān)系映射的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07SpringBoot如何優(yōu)雅地使用Swagger2
這篇文章主要介紹了SpringBoot如何優(yōu)雅地使用Swagger2,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07Spring Boot實(shí)現(xiàn)異步請(qǐng)求(Servlet 3.0)
在spring 3.2 及以后版本中增加了對(duì)請(qǐng)求的異步處理,這篇文章主要介紹了Spring Boot實(shí)現(xiàn)異步請(qǐng)求(Servlet 3.0),感興趣的小伙伴們可以參考一下。2017-04-04完美解決gson將Integer默認(rèn)轉(zhuǎn)換成Double的問題
下面小編就為大家?guī)硪黄昝澜鉀Qgson將Integer默認(rèn)轉(zhuǎn)換成Double的問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03