博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mybatis关联查询(嵌套查询)
阅读量:5902 次
发布时间:2019-06-19

本文共 2948 字,大约阅读时间需要 9 分钟。

文章介绍了基于Mybatis对数据库的增、删、改、查。这一篇介绍下关联查询(join query)。

三张表:user article blog

表的存储sql文件:

 
View Code

配置文件Configuration.xml

User类的定义和User.xml的配置见上一文章。

Article类定义:

 
View Code

Article类中有一个User类。

Article.xml的配置:

Blog类定义:

 
View Code

Blog类中有一个List<Article>。

Blog.xml配置:

IArticleOperation定义:

package com.mybatis.test;import java.util.List;public interface IArticleOperation {    public List
getUserArticles(int userID);}

IBlogOperation定义:

package com.mybatis.test;public interface IBlogOperation {        Blog getBlogByID(int id);    }

Test类:

 
View Code

Mybatis的“N+1查询问题”

示例:

有两个查询语句:一个来加载博客,另外一个来加载作者,而且博客的结果映射描述了“selectAuthor”语句应该被用来加载它的 author 属性。

其他所有的属性将会被自动加载,假设它们的列和属性名相匹配。

这种方式很简单,但是对于大型数据集合和列表将不会表现很好。问题就是我们熟知的“N+1 查询问题”。概括地讲,N+1 查询问题可以是这样引起的:

你执行了一个单独的 SQL 语句来获取结果列表(就是“+1”)。

对返回的每条记录,你执行了一个查询语句来为每个加载细节(就是“N”)。

这个问题会导致成百上千的 SQL 语句被执行。这通常不是期望的。

可以采用关联的嵌套结果来解决这个问题:

resultMap 这是结果映射的 ID,可以映射关联的嵌套结果到一个合适的对象图中。这是一种替代方法来调用另外一个查询语句。

 

代码下载:http://download.csdn.net/detail/luxiaoxun/8056559

 

参考:

http://www.mybatis.org/mybatis-3/zh/sqlmap-xml.html

    本文转自阿凡卢博客园博客,原文链接:http://www.cnblogs.com/luxiaoxun/p/4035276.html,如需转载请自行联系原作者

你可能感兴趣的文章
存储过程—导出table数据为inser sqlt语句
查看>>
Windows 7下Maven3.0.3的安装
查看>>
CISCO2691的OSPF点对点密文测评测试
查看>>
POJ 1661 Help Jimmy(递推DP)
查看>>
Node.js 中文学习资料和教程导航
查看>>
查找(AVL平衡二叉树)
查看>>
Javascript函数调用的四种模式
查看>>
用 Asterisk 搭建自己的免费 VoIP 服务器
查看>>
lua笔记二 赋值语句
查看>>
Android 中 Internal Storage 和 External Storage 的区别
查看>>
移动端拖拽(模块化开发,触摸事件,webpack)
查看>>
spring配置和注解事务同时存在导致的事务嵌套
查看>>
AE要素选择(点选和拉框选择)
查看>>
AJAX-初学AJAX本地环境配置
查看>>
Java内存模型深度解析:顺序一致性--转
查看>>
VSCode调试配置
查看>>
前端MVC学习总结(三)——AngularJS服务、路由、内置API、jQueryLite
查看>>
Selenium Web 自动化 - 项目持续集成(进阶)
查看>>
java&javaweb学习笔记
查看>>
UML统一建模语UML2和EnterpriseArchitect
查看>>