版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SDDDLLL/article/details/85254565
自关联就是自己既可以充当一方,又可以充当多方。比如说新闻栏目,既可以做父栏目(一方),也可以做子栏目(多方)。而反映到数据库中只有一张表,这张表只有一个外键,一级栏目没有父栏目所以将外键设为0,子栏目有外键值。下面以新闻栏目为例讲解。
下面分两种情况:充当一方和充当多方
1、建表(newslabel)
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
充当多方