电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

mybatis通過中間表實現一對多查詢功能

瀏覽:2日期:2023-10-18 10:59:34

需求:通過一個學生的id查詢出該學生所學的所有科目。

使用到的表格:1.student:學生表

mybatis通過中間表實現一對多查詢功能

2.subject:科目表

mybatis通過中間表實現一對多查詢功能

3.stu_sub:學生-科目表(這里的成績字段沒用到,不用管)

mybatis通過中間表實現一對多查詢功能

實體類( get、set方法省略):1.student

public class Student implements Serializable { private int id; private String stuNum; //學號 private String password; private String stuName; private String grade; //年級 private String department; //系 private String professional; //專業 private List<Subject> subList; //修讀課程}

2.subject

public class Subject implements Serializable { private Integer id; private String subjectName; }

首先記一次錯誤的實踐:最開始的想法很美好,思路示例如下:首先通過stu_sub語句塊在中間表查詢出學生id對應的subId,在通過resultMap里面的collection標簽將subId傳到stu_sub_1語句塊中,實現聯級查詢。

mybatis通過中間表實現一對多查詢功能

結果:可以查詢出該學生對應的所有科目,但是無法封裝到student實體類的List<subject.>屬性中,會報錯期望的返回值是1,但結果是n。原因:mybatis若是沒有用主鍵來查詢對多關系,就會把查詢出來的多個結果當成多個對象來封裝。如上述例子,第一步通過stu_sub語句塊查詢出來的結果為:

mybatis通過中間表實現一對多查詢功能

這時候由于resultMap的type是student類型,所以mybatis會把上述的4個stuId當成四個對象來存放collection查詢出來的科目。但我們方法的返回值是Student,所以會因為無法存放4個student而報錯。

-------------------------------------------------------------分割線----------------------------------------------------------------下面是成功實現的示例:直接使用left join語句將三個表關聯查詢,再通過resultMap將我們所需要的學科注入到student對象中。xml代碼實現如下:

<resultMap type='student'><id column='id' property='id'></id><result column='stuNum' property='stuNum'></result><result column='stuName' property='stuName'></result><result column='grade' property='grade'></result><result column='department' property='department'></result><result column='professional' property='professional'></result><collection property='subList' ofType='subject'> <!--將subject的id改成其他別名,不然會跟student的id字段沖突--> <id column='sub_id' property='id'></id> <result column='subjectName' property='subjectName'></result></collection> </resultMap> <select resultMap='Map_stu_sub'> SELECT a.*,c.id as sub_id,c.subjectName FROM student a LEFT OUTER JOIN stu_sub b ON a.id=b.stuId LEFT JOIN SUBJECT c ON b.subId=c.id WHERE a.id = #{id} </select>

然后直接調用stu_sub方法即可。

到此這篇關于mybatis通過中間表實現一對多查詢的文章就介紹到這了,更多相關mybatis一對多查詢內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 整合营销推广|营销网络推广公司|石家庄网站优化推广公司|智营销 好物生环保网、环保论坛 - 环保人的学习交流平台 | 河南橡胶接头厂家,河南波纹补偿器厂家,河南可曲挠橡胶软连接,河南套筒补偿器厂家-河南正大阀门 | CTAB,表面活性剂1631溴型(十六烷基三甲基溴化铵)-上海升纬化工原料有限公司 | 德国BOSCH电磁阀-德国HERION电磁阀-JOUCOMATIC电磁阀|乾拓百科 | 申江储气罐厂家,储气罐批发价格,储气罐规格-上海申江压力容器有限公司(厂) | 污水处理设备,一体化泵站,一体化净水设备-「梦之洁环保设备厂家」 | 道康宁消泡剂-瓦克-大川进口消泡剂供应商| 焦作网 WWW.JZRB.COM| 甲级防雷检测仪-乙级防雷检测仪厂家-上海胜绪电气有限公司 | 层流手术室净化装修-检验科ICU改造施工-华锐净化工程-特殊科室建设厂家 | 电力测功机,电涡流测功机,磁粉制动器,南通远辰曳引机测试台 | 软装设计-提供软装装饰和软装配饰及软装陈设的软装设计公司 | 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 | 实验室装修_实验室设计_实验室规划设计- 上海广建净化工程公司 | 创绿家招商加盟网-除甲醛加盟-甲醛治理加盟-室内除甲醛加盟-创绿家招商官网 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 艺术涂料|木纹漆施工|稻草漆厂家|马来漆|石桦奴|水泥漆|选加河南天工涂料 | 陕西自考报名_陕西自学考试网 | 打孔器,打孔钳厂家【温州新星德牌五金工具】 | 哈尔滨发电机,黑龙江柴油发电机组-北方星光 | 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 英国雷迪地下管线探测仪-雷迪RD8100管线仪-多功能数字听漏仪-北京迪瑞进创科技有限公司 | 电动高压冲洗车_价格-江苏速利达机车有限公司 | 彩信群发_群发彩信软件_视频短信营销平台-达信通 | 布袋除尘器-单机除尘器-脉冲除尘器-泊头市兴天环保设备有限公司 布袋除尘器|除尘器设备|除尘布袋|除尘设备_诺和环保设备 | 万家财经_财经新闻_在线财经资讯网| 重庆小面培训_重庆小面技术培训学习班哪家好【终身免费复学】 | 蓝牙音频分析仪-多功能-四通道-八通道音频分析仪-东莞市奥普新音频技术有限公司 | 液晶拼接屏厂家_拼接屏品牌_拼接屏价格_监控大屏—北京维康 | 能量回馈_制动单元_电梯节能_能耗制动_深圳市合兴加能科技有限公司 | 艺术涂料_进口艺术涂料_艺术涂料加盟_艺术涂料十大品牌 -英国蒙太奇艺术涂料 | 餐饮小吃技术培训-火锅串串香培训「何小胖培训」_成都点石成金[官网] | CCC验厂-家用电器|服务器CCC认证咨询-奥测世纪| 智能案卷柜_卷宗柜_钥匙柜_文件流转柜_装备柜_浙江福源智能科技有限公司 | 广东健伦体育发展有限公司-体育工程配套及销售运动器材的体育用品服务商 | 日本东丽膜_反渗透膜_RO膜价格_超滤膜_纳滤膜-北京东丽阳光官网 日本细胞免疫疗法_肿瘤免疫治疗_NK细胞疗法 - 免疫密码 | 北京律师咨询_知名专业北京律师事务所_免费法律咨询 | 单机除尘器 骨架-脉冲除尘器设备生产厂家-润天环保设备 | 刚性-柔性防水套管-橡胶伸缩接头-波纹管补偿器-启腾供水材料有限公司 | 非小号行情 - 专业的区块链、数字藏品行情APP、金色财经官网 | R507制冷剂,R22/R152a制冷剂厂家-浙江瀚凯制冷科技有限公司 |