首先,mybatis本身不會(huì)判斷是否是多表查詢,mybatis的多表查詢和單表查詢其實(shí)沒(méi)有什么區(qū)別,你都需要一個(gè)對(duì)象接收返回值。
創(chuàng)新互聯(lián)是一家成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè),提供網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),網(wǎng)站制作,建網(wǎng)站,按需求定制設(shè)計(jì),網(wǎng)站開(kāi)發(fā)公司,于2013年成立是互聯(lián)行業(yè)建設(shè)者,服務(wù)者。以提升客戶品牌價(jià)值為核心業(yè)務(wù),全程參與項(xiàng)目的網(wǎng)站策劃設(shè)計(jì)制作,前端開(kāi)發(fā),后臺(tái)程序制作以及后期項(xiàng)目運(yùn)營(yíng)并提出專業(yè)建議和思路。
例如:select u.name name,p.grade grade from table_1 u,table_2 p where u.id = p.id。這里你從兩張表里查出兩個(gè)字段name和grade,那么你就需要映射到對(duì)應(yīng)的對(duì)象中去。新建一個(gè)VO,包含你所要查詢的對(duì)象,并一一映射即可。
希望可以幫到你。
一個(gè)簡(jiǎn)單的案例
select 表_1.*,表_2.*
from 表_1,表_2
where
表_1.姓名=表_2.性名
and
表_1.性別='男'
and
表_2.字段336
多表查詢
分類: 主要看看兩個(gè)表之間有什么聯(lián)系
user1 主鍵 id (1對(duì)多關(guān)系)
item 里面有一個(gè)字段 user_id
查詢非常簡(jiǎn)單 只需要user1.user1=item .user_id
select 前臺(tái)用戶選擇的列(別名.XX1,別名.XX2,別名.XX3...)
from 前臺(tái)用戶選擇要查詢的表(T1) 別名 [,T2,T3]
[
連接關(guān)系(內(nèi)連,左連)(inner join, left join) 表(T2) on
連接條件(表1別名.列名=表2別名.列名)
]
where 1=1 and [查詢條件(表1別名.列名=xxx,...)]
[order by 表1別名.列名]
PS:方括號(hào)的內(nèi)容為可選
補(bǔ)充回答:
怎么會(huì)不知道用戶選了什么列呢?比如圖中選了證書(shū)號(hào),證書(shū)類型,簽證機(jī)構(gòu),它選中肯定會(huì)對(duì)應(yīng)一個(gè)值的,把這個(gè)值設(shè)成列名不就可以直接拼接了嗎
多表查詢是屬于數(shù)據(jù)庫(kù)的知識(shí), 按照你說(shuō)的使用java進(jìn)行多表查詢那就要使用Hibernate,此ORM框架將數(shù)據(jù)庫(kù)的關(guān)系映射成了java代碼的形式。
通過(guò)配置映射文件(*.hbm.xml) 設(shè)置好關(guān)聯(lián)關(guān)系就可以了。也不知道你具體的表結(jié)構(gòu)是什么樣子的。
另外:比較簡(jiǎn)單的 你直接用sql代碼的左右連接也可以實(shí)現(xiàn)多表查詢, 甚至如果你基礎(chǔ)差點(diǎn),可以分成幾句sql語(yǔ)句, 逐步完成查找。 也不清楚你的表結(jié)構(gòu),具體代碼就不給出了。
當(dāng)前題目:java多表查詢代碼,java多表聯(lián)合查詢
URL分享:http://muchs.cn/article38/phjgpp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司、面包屑導(dǎo)航、品牌網(wǎng)站建設(shè)、建站公司、用戶體驗(yàn)、軟件開(kāi)發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)