Mybatis多对多映射关系详解

首先数据库的创建    如图



user表属性


orders表属性


进行主外键关联如图




创建ordersdemo



进行主外键关联 如图



创建item



这样数据库就设计好了 测试一下


  • 7
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Mybatis中,处理多对多关系可以参考一对多关系的解决方法。需要注意的是,如果在映射中存在多个字段具有相同的名称(例如id),则需要为这些列起别名以避免冲突。以下是一个多对多关系的案例讲解: 1、首先,我们需要创建三张表:course、student和student_course。course表存储课程信息,student表存储学生信息,student_course表存储学生和课程之间的关联关系。 2、创建表的SQL语句如下: drop table student_course; drop table course; drop table student; 如果需要可以使用 cascade constraints; create table course (id number primary key,course_code varchar2(30) not null,course_name varchar2(30) not null); create table student (id number primary key,name varchar2(10) not null,gender varchar2(10),major varchar2(10),grade varchar2(10)); create table student_course (id number primary key,student_id number references student(id),course_id number references course(id)); 3、在Mybatis映射文件中,我们需要使用多个resultMap来定义多对多关系映射。例如,我们可以定义一个学生的resultMap和一个课程的resultMap,并在学生的resultMap中使用collection标签来引用课程的resultMap,从而建立多对多关系。 4、在业务逻辑中,我们可以通过Mybatis的动态SQL语句来实现多对多关系的操作。例如,通过插入学生和课程的id来向student_course表中插入数据,通过查询student_course表来获取学生所选的课程等等。 总结来说,处理Mybatis中的多对多关系,可以参考一对多关系的解决方法,并使用动态SQL语句和多个resultMap来实现。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Mybatis多对多映射详解](https://blog.csdn.net/suwu150/article/details/52896466)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [SSM框架的学习与应用-Java EE企业级应用开发学习记录(第一天)Mybatis的学习资料](https://download.csdn.net/download/m0_53659738/88235079)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值