国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看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教程 - MyBatis-Plus 如何實(shí)現(xiàn)連表查詢的示例代碼

MyBatis-Plus 如何實(shí)現(xiàn)連表查詢的示例代碼

2020-08-25 00:16liujianko Java教程

這篇文章主要介紹了MyBatis-Plus 如何實(shí)現(xiàn)連表查詢的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在項(xiàng)目開發(fā)中,難免會(huì)遇到連表查詢的操作。

項(xiàng)目中用的是 MyBatis-Plus,是新使用的框架。官方文檔看這里

我寫過一篇通過單元測(cè)試來驗(yàn)證 MyBatis-Plus 的 CRUD 操作。點(diǎn)這里跳轉(zhuǎn)

今天遇到連表查詢的問題,特此記錄一下。

遇到需要連表操作,想起 MyBatis 的操作連表查詢,要是 MyBatis-Plus 也像 MyBatis 一樣,就腦殼痛了。(MyBatis-Plus 是 MyBatis 的增強(qiáng)版)

腦殼痛歸腦殼痛,先動(dòng)手干。

首先

因?yàn)楣俜降膬?nèi)置接口方法都是針對(duì)單表的,所以要連表的話,還是得中規(guī)中矩來。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// 第一步,在 mapper.java 類中定義一個(gè)連表查詢的方法 selectTsxxWsla
public interface WTsxxMapper extends SuperMapper<WTsxx> {
 List<Object> selectTsxxWsla();
}
 
// 第二步,在 mapper.xml 中定義 id='selectTsxxWsla' 的查詢塊
<mapper namespace="com.haoda.sswfw.dao.primary.mapper.WTsxxMapper">
 <select id="selectTsxxWsla" resultType="map">
 SELECT a.*,CONCAT(b.xxid,'') AS xxid,b.nr,b.xxbt,b.weixzt,b.ywlxbm,b.createtime,b.glid
 FROM v_weix_user a,w_tsxx b
 JOIN (
   SELECT xxid,user_name,createtime FROM w_tsxx_user
    ) c ON b.xxid = c.xxid
 WHERE a.user_name = c.user_name AND a.openid != '' AND b.weixzt = '2' AND b.errcode IS NULL AND LOWER(b.ywlxbm) = 'wsla'
 </select>
</mapper>
 
// 第三步,直接寫測(cè)試用例,看看能出來什么效果
@RunWith(SpringRunner.class)
@SpringBootTest
public class DbTest {
 @Autowired
 private WTsxxMapper tsxxMapper;
 
 @Test
 public void test3() {
 List<Object> selectTsxxWsla = tsxxMapper.selectTsxxWsla();
 for (Object obj : selectTsxxWsla) {
  System.out.println(obj);
 }
 }
}

 運(yùn)行結(jié)果出來發(fā)現(xiàn),select 語句中的字段都封裝成 Object,存到 List 集合中去了,不過有一點(diǎn)就是如果字段的值是 null 的,就不會(huì)封到 Object 里。

有點(diǎn)小開心

回顧一下我上次在 MyBatis 的連表方式,首先我在主表的實(shí)體類中把需要連表的實(shí)體類加進(jìn)去了。

然后在 mapper.xml 添加了 association 標(biāo)簽,用來配置關(guān)聯(lián)關(guān)系的。

然后

我發(fā)現(xiàn)可以封裝 Object,那我想是不是就可以自定義一個(gè) VO 來封裝成一個(gè)實(shí)體類。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// 將查詢字段 自定義成 WxTsxxVo
public class WxTsxxVo {
 private String openid;
 private String unionid;
 private Long user_id;
 private String user_name;
 .....
}
 
// 原本 List<Object> 替換成 List<WxTsxxVo>
public interface WTsxxMapper extends SuperMapper<WTsxx> {
 List<WxTsxxVo> selectTsxxWsla();
}
 
// 原本 List<Object> 替換成 List<WxTsxxVo>
@Test
public void test3() {
 List<WxTsxxVo> selectTsxxWsla = tsxxMapper.selectTsxxWsla();
 for (WxTsxxVo obj : selectTsxxWsla) {
 System.out.println(obj);
 }
}

然后很開心運(yùn)行了 test3,想著結(jié)果應(yīng)該沒問題的了,結(jié)果報(bào)錯(cuò)了,報(bào)了個(gè)轉(zhuǎn)換異常,不能轉(zhuǎn)換成 WxTsxxVo 對(duì)象。

不對(duì)啊,Object 都沒有報(bào)錯(cuò),我定義了個(gè) WxTsxxVo 實(shí)體就報(bào)錯(cuò)了?

后來想想應(yīng)該是查詢出來的結(jié)果不認(rèn)識(shí)我這個(gè) WxTsxxVo,網(wǎng)上搜了一下「連表查詢封裝進(jìn)自定義實(shí)體類」,看到有個(gè)解決方案是 添加association標(biāo)簽,還有另外一個(gè)解決方案是在 mapper.xml 中寫一個(gè)對(duì)應(yīng)的 resultMap

所以我選擇嘗試第二種方案。

運(yùn)行成功

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// 對(duì)應(yīng) WxTsxxVo 實(shí)體類,寫了一個(gè)對(duì)應(yīng)的 resultMap
<resultMap id="WxTsxxVo" type="com.haoda.sswfw.job.vo.WxTsxxVo">
   <result column="openid" property="openid" />
   <result column="unionid" property="unionid" />
   <result column="user_id" property="user_id" />
   <result column="user_name" property="user_name" />
   ...
</resultMap >
 
// 原先的 resultType="map" 替換成 resultMap="WxTsxxVo"
<select id="selectTsxxWsla" resultMap="WxTsxxVo">
 SELECT a.*,CONCAT(b.xxid,'') AS xxid,b.nr,b.xxbt,b.weixzt,b.ywlxbm,b.createtime,b.glid
 FROM v_weix_user a,w_tsxx b
 JOIN (
   SELECT xxid,user_name,createtime FROM w_tsxx_user
   ) c ON b.xxid = c.xxid
 WHERE a.user_name = c.user_name AND a.openid != '' AND b.weixzt = '2' AND b.errcode IS NULL AND LOWER(b.ywlxbm) = 'wsla'
</select>

再次運(yùn)行,這次就成功了。查詢出來的每條結(jié)果都封裝成 WxTsxxVo,然后在放到 List 集合里面。

總結(jié)
1.新框架需要多點(diǎn)嘗試,所以寫測(cè)試用例就很重要了。
2.MyBatis 也許也能像上面一樣,并不需要在主表的實(shí)體類里面關(guān)聯(lián)另外一個(gè)實(shí)體,不過有機(jī)會(huì)還是可以試試看的。

到此這篇關(guān)于MyBatis-Plus 如何實(shí)現(xiàn)連表查詢的示例代碼的文章就介紹到這了,更多相關(guān)MyBatis-Plus 連表查詢內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家! 

原文鏈接:https://blog.csdn.net/godbrian/article/details/89562499

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 精品国产欧美一区二区 | 狠狠色噜噜 | 久久成人免费视频 | 九色在线 | 精品日韩一区二区 | 中文字幕在线三区 | 久久久久久中文字幕 | 伊大人久久香线焦宗合一75大 | 国产成人精品一区二区 | 成人欧美一区二区三区在线播放 | 一区二区三区国产在线 | 午夜影院在线 | 日本一区二区在线视频 | 精品国产一区二区三区久久久 | 久久精品国产一区二区电影 | 免费黄色在线观看 | 黄色一级视频 | 欧美专区在线观看 | 二区视频 | 久久久久中文字幕 | 亚洲va欧美va人人爽成人影院 | 欧美久久久久久久久久久久久久 | 欧美日韩成人精品 | 精品一区二区三区在线观看 | 午夜精品福利在线观看 | 天天综合网网欲色 | 欧美色综合天天久久综合精品 | 欧美大片高清在线观看平台 | 欧美日韩国产一区二区三区在线观看 | 久久久国产视频 | 欧美一区视频 | 在线视频国产一区 | 亚洲欧美激情精品一区二区 | 这里只有久久精品 | 欧美日韩在线一区二区三区 | 成人在线小视频 | 免费一级特黄3大片视频 | 成人在线免费小视频 | 久久中文字幕一区 | 亚洲精品中文字幕 | 超碰在线观看97 |