Mybatis中的连接查询与嵌套查询

Mybatis中的连接查询与嵌套查询查询 a 表的所有信息 如果 a 表的信息有对应的 b 表的信息 则查询 b 表的信息 如果没有 则不查询 多对一 如 查询所有城市信息 如果城市有对应国家 则查询国家信息 如果没有 则不查询 多个城市属于一个国家 一对多 如 查询所有国家信息 如果国家有对应城市 则查询城市信息 如果没有 则不查询 一个国家拥有多个城市 多对多 如 查询所有国家信息 如果国家与对应拥有的动物 则查询动物信息 没有则不查

首先在mysql中确立表:

#表一:地址国家表 CREATE TABLE address(aid INT AUTO_INCREMENT PRIMARY KEY,aname VARCHAR(20)); INSERT INTO address VALUES(NULL,"魏国"); INSERT INTO address VALUES(NULL,"蜀国"); INSERT INTO address VALUES(NULL,"吴国"); #表二:出场人物表 CREATE TABLE person( pid INT AUTO_INCREMENT PRIMARY KEY, pname VARCHAR(20), paid INT, CONSTRAINT pafk FOREIGN KEY person(paid) REFERENCES address(aid) ON UPDATE CASCADE ON DELETE CASCADE ); INSERT INTO person VALUES(1,"曹操",1); INSERT INTO person VALUES(2,"荀彧",1); INSERT INTO person VALUES(3,"张辽",1); INSERT INTO person VALUES(4,"刘备",2); INSERT INTO person VALUES(5,"关羽",2); INSERT INTO person VALUES(6,"张飞",2); INSERT INTO person VALUES(7,"诸葛亮",2); INSERT INTO person VALUES(8,"孙权",3); INSERT INTO person VALUES(9,"周瑜",3); INSERT INTO person VALUES(10,"陆逊",3); INSERT INTO person VALUES(11,"公孙瓒",NULL); #表三:交通工具表 CREATE TABLE tool(tid INT AUTO_INCREMENT PRIMARY KEY,tname VARCHAR(20)); INSERT INTO tool VALUES(1,"马"); INSERT INTO tool VALUES(2,"船"); #表四:地址国家——交通工具 多对多关系表 CREATE TABLE aandt( a_aid INT, a_tid INT, PRIMARY KEY(a_aid,a_tid),#联合主键,是指多个字段组成一个组合,该组合在数据表中唯一 CONSTRAINT FOREIGN KEY aandt(a_aid) REFERENCES address(aid) ON UPDATE CASCADE ON DELETE CASCADE, CONSTRAINT FOREIGN KEY aandt(a_tid) REFERENCES tool(tid) ON UPDATE CASCADE ON DELETE CASCADE ); INSERT INTO aandt VALUES(1,1); INSERT INTO aandt VALUES(2,1); INSERT INTO aandt VALUES(2,2); INSERT INTO aandt VALUES(3,2); 

查询a表的所有信息,如果a表的信息有对应的b表的信息,则查询b表的信息,如果没有,则不查询。

一、连接查询:
连接查询使用时,使用偏向于a表所在方向的外连接,可获得a表所有信息,和对应的b表信息。该方式为饿汉式,内存占用较大,但对数据库访问次数较少而导致消耗时间少。
1、多对一:




 
   
   
    
    
     
     
     
     
     
     
      
      
      
     
    
    
   

2、一对多:

 
   
   
    
     
     
     
      
      
      
      
     
    
    
   

3、多对多:

 
   
    
     
     
     
      
      
     
    
    
  

二、嵌套查询:
嵌套查询使用时,先查询a表的信息,然后依赖a和b表的外键约束,利用in(),再次查询b表对应到a表上的信息。该方式可以改为饿汉式,内存使用较小,但需要多次访问数据库而导致消耗时间多。
1、多对一:
PersonDao接口内写入:






//查询所有人,以及其对应的地址 List 
  
    findPersonFromAddress(); 
  

对应映射配置中:

 
   
   
    
    
     
     
     
     
     
    
    
    
   

继续编写指向AddressDao接口中的findAddressById:

//按照id查询Address List 
findAddressById(Integer id);

回到AddressDao配置文件:

 
   
    
    
  
List 
findAddressWithPerson();

其对应映射配置中:

 
   
    
    
    
    

针对指出的PersonDao接口的findPersonById:

 List 
  
    findPersonById(Integer id); 
  

其对应的映射配置中:

 
 
   
    
    
    
   
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/176682.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午9:19
下一篇 2026年3月26日 下午9:19


相关推荐

  • Docker OpenClaw 生产环境部署指南(单机架构版)

    Docker OpenClaw 生产环境部署指南(单机架构版)

    2026年3月13日
    3
  • 谷歌离线地图Api附获取教程[通俗易懂]

    谷歌离线地图Api附获取教程[通俗易懂]GoogleMapAPIV3来自:https://www.cnblogs.com/liongis/archive/2011/04/28/2032316.htmlGoogleMapsAPI_OfflineDebugPack来自:https://www.cnblogs.com/Tangf/archive/2009/02/20/1394511.html两个Api下载链接:https://pan.baidu.com/s/1SfRccuFHo1qsQyKK_LJBiA提取码:t64t从谷歌官方网站获取最

    2026年2月4日
    15
  • 不要再问芝士和奶酪有什么区别了!一次解释清楚「建议收藏」

    不要再问芝士和奶酪有什么区别了!一次解释清楚「建议收藏」在西方,奶酪绝对是全民食物,无论男女老少,很多都是“没奶酪会死星人”。两位世界知名大佬都曾对它发表过经典言论,丘吉尔在二战时说,一个为世界提供300种以上奶酪的国家是不应该灭亡的。而戴高乐总统的看法则是:“要统治一个拥有600种奶酪的国家,是很困难的。”    但在中国,它的接受面好像还真没那么广,如果深究起来是有很多方面的原因,包括历史、地域、文化等,说起来也是太复杂,还有奶酪的

    2022年4月20日
    63
  • ideamaven仓库设置_搭建maven仓库

    ideamaven仓库设置_搭建maven仓库1、Maven下载在maven官网下载maven安装:http://maven.apache.org/download.cgi下载之后解压到安装路径:完成安装。2、Maven本地仓库配置在本地新建本地仓库文件夹,替代默认新建在系统盘的仓库地址,因为随着时间,仓库会越来越大,所以建议自己新建一个本地仓库:Maven远程库也是位于网络上的存储库。因为maven在获取需要的jar包时会首先从本地仓库获取,当本地仓库不存在需要的jar包时会从setting.xml的…

    2026年2月25日
    4
  • OpenClaw 安装完整教程以及国内大模型配置指南

    OpenClaw 安装完整教程以及国内大模型配置指南

    2026年3月13日
    2
  • 不止一个背包的背包问题_超级背包怎么使用方法

    不止一个背包的背包问题_超级背包怎么使用方法有 N 个物品和一个容量是 V 的背包。物品之间具有依赖关系,且依赖关系组成一棵树的形状。如果选择一个物品,则必须选择它的父节点。如下图所示:如果选择物品5,则必须选择物品1和2。这是因为2是5的父节点,1是2的父节点。每件物品的编号是 i,体积是 vi,价值是 wi,依赖的父节点编号是 pi。物品的下标范围是 1…N。求解将哪些物品装入背包,可使物品总体积不超过背包容量,且总价值最大。输出最大价值。输入格式第一行有两个整数 N,V,用空格隔开,分别表示物品个数和背包容量。接下来有 N

    2022年8月9日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号