Mybatis学习(10)多表之自关联查询

自关联就是自己既可以充当一方,又可以充当多方。比如说新闻栏目,既可以做父栏目(一方),也可以做子栏目(多方)。而反映到数据库中只有一张表,这张表只有一个外键,一级栏目没有父栏目所以将外键设为0,子栏目有外键值。下面以新闻栏目为例讲解。

下面分两种情况:充当一方和充当多方

1、建表(newslabel)

2、以一对多方式处理(充当一方)

这种情况也就是充当父栏目,通过查询父栏目,可以找到这个父栏目的子栏目。而这种方式也有两种情况:

  1. 查询出指定栏目的所有子孙栏目(不包含本身)
  2. 查询出指定栏目及其所有子孙栏目(包含自身)

A:查询指定栏目的所有子孙栏目(不包含自身)

根据父栏目的id,查询出所有子栏目

a、定义实体类

b、定义dao接口

c、定义mapper映射

这里通过select语句的递归调用实现查询所有下级栏目的功能。

d、定义测试类

B、查询指定栏目及其所有子孙栏目(包含自身)

这里的查询结果,既要包含父栏目,也要包含所有的子孙栏目

a、修改Dao接口

b、修改mapper映射

c、修改测试类

 

3、以多对一方式处理(充当多方)

以多对一方式处理,也就是说多方可以看到一方,也就是说通过子栏目的id,可以得到所有父栏目

a、定义实体类

b、定义Dao接口

c、定义mapper映射

d、定义测试类

总结

自关联查询的关键在于mapper的书写,往下查询时候应该是collection,往上查询时候是association。以及里面相应的参数。

附上源码地址:

充当一方

https://download.csdn.net/download/sdddlll/10876490

充当多方

https://download.csdn.net/download/sdddlll/10876493

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis关联查询是指在查询数据库时,通过配置映射文件,将多个之间的关联数据查询出来并进行组合。可以使用嵌套结果映射或嵌套查询来处理关联查询。 在嵌套结果映射中,可以使用\<resultMap>来定义映射关系,并使用\<association>来设置关联对象。例如,可以定义一个resultMap来映射Classes和Teacher之间的关联关系,然后通过联查询将两个的数据关联起来。 另一种方式是使用嵌套查询,即在映射文件中通过\<select>标签设置嵌套查询语句来获取关联数据。通过联查询获取到的数据可以作为嵌套查询的参数,从而获取到关联数据。 以上就是MyBatis关联查询的基本概念和使用方式。可以根据具体的需求选择合适的方式进行关联查询操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SSM框架的学习与应用-Java EE企业级应用开发学习记录(第四天)Mybatis的关联映射和缓存机制](https://download.csdn.net/download/m0_53659738/88253127)[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%"] - *2* *3* [mybatis关联查询](https://blog.csdn.net/faramita_of_mine/article/details/122202515)[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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值