MyBatis-3
1.1 一对一查询
用户表和订单表的关系为,一个用户有多个订单,一个订单只从属于一个用户
一对一查询的需求:查询一个订单,与此同时查询出该订单所属的用户
1.1.2一对一查询的语句
对应的sql语句:select * from orders o,user u where o.uid=u.id;
查询的结果如下:
1.1.3 创建Order和User实体
1.1.4 创建OrderMapper接口
1.1.5 配置OrderMapper.xml
其中<resultMap>还可以配置如下:
1.1.6 测试结果
1.2 一对多查询
1.2.1 一对多查询的模型
用户表和订单表的关系为,一个用户有多个订单,一个订单只从属于一个用户
一对多查询的需求:查询一个用户,与此同时查询出该用户具有的订单
1.2.2 一对多查询的语句
对应的sql语句:select *,o.id oid from user u left join orders o on u.id=o.uid;
查询的结果如下:
1.2.3 修改User实体
1.2.4 创建UserMapper接口
1.2.5 配置UserMapper.xml
1.2.6 测试结果
1.3 多对多查询
1.3.1 多对多查询的模型
用户表和角色表的关系为,一个用户有多个角色,一个角色被多个用
多对多查询的需求:查询用户同时查询出该用户的所有角色
对应的sql语句:select u.,r.,r.id rid from user u left join user_role ur on u.id=ur.user_id
inner join role r on ur.role_id=r.id;
查询的结果如下:
1.3.3 创建Role实体,修改User实体
1.3.4 添加UserMapper接口方法
1.3.5 配置UserMapper.xml
1.3.6 测试结果
1.4 知识小结
MyBatis多表配置方式:
一对一配置:使用<resultMap>做配置
一对多配置:使用<resultMap>+<collection>做配置
多对多配置:使用<resultMap>+<collection>做配置
2.Mybatis的注解开发
2.1 MyBatis的常用注解
这几年来注解开发越来越流行,Mybatis也可以使用注解开发方式,这样我们就可以减少编写Mapper映射文件了。我们先围绕一些基本的CRUD来学习,再学习复杂映射多表操作。
@Insert:实现新增
@Update:实现更新
@Delete:实现删除
@Select:实现查询
@Result:实现结果集封装
@Results:可以与@Result 一起使用,封装多个结果集
@One:实现一对一结果集封装
@Many:实现一对多结果集封装
2.2 MyBatis的增删改查
我们完成简单的user表的增删改查的操作
修改MyBatis的核心配置文件,我们使用了注解替代的映射文件,所以我们只需要加载使用了注解的Mapper接口即可
或者指定扫描包含映射关系的接口所在的包也可以
2.3 MyBatis的注解实现复杂映射开发
实现复杂关系映射之前我们可以在映射文件中通过配置<resultMap>来实现,使用注解开发后,我们可以使用@Results注解,@Result注解,@One注解,@Many注解组合完成复杂关系的配置
2.4 一对一查询
2.4.1 一对一查询的模型
用户表和订单表的关系为,一个用户有多个订单,一个订单只从属于一个用户
一对一查询的需求:查询一个订单,与此同时查询出该订单所属的用户
2.4.2 一对一查询的语句
对应的sql语句:
查询的结果如下:
2.4.3 创建Order和User实体
2.4.4 创建OrderMapper接口
2.4.5 使用注解配置Mapper
2.4.6 测试结果
2.5 一对多查询
2.5.1 一对多查询的模型
用户表和订单表的关系为,一个用户有多个订单,一个订单只从属于一个用户
一对多查询的需求:查询一个用户,与此同时查询出该用户具有的订单
2.5.2 一对多查询的语句
对应的sql语句:
查询的结果如下:
2.5.3 修改User实体
2.5.4 创建UserMapper接口
2.5.5 使用注解配置Mapper
2.5.6 测试结果
2.6 多对多查询
2.6.1 多对多查询的模型
用户表和角色表的关系为,一个用户有多个角色,一个角色被多个用户使用
多对多查询的需求:查询用户同时查询出该用户的所有角色
2.6.2 多对多查询的语句
对应的sql语句:
查询的结果如下:
2.6.3 创建Role实体,修改User实体
2.6.4 添加UserMapper接口方法
2.6.5 使用注解配置Mapper
2.6.6 测试结果
SSM框架整合
1.1 原始方式整合
1.准备工作
2.创建Maven工程
3.导入Maven坐标
参考:素材/配置文件/pom.xml文件
4.编写实体类
5.编写Mapper接口
6.编写Service接口
7.编写Service接口实现
8.编写Controller
9.编写添加页面
10.编写列表页面
11.编写相应配置文件(文件参考目录:素材/配置文件)
•Spring配置文件:
•SprngMVC配置文件:
•MyBatis映射文件:
•MyBatis核心文件:
•数据库连接信息文件:
•Web.xml文件:
•日志文件:[log4j.xml](
12.测试添加账户
13.测试账户列表
1.2 Spring整合MyBatis
1.整合思路
2.将SqlSessionFactory配置到Spring容器中
3.扫描Mapper,让Spring容器产生Mapper实现类
4.配置声明式事务控制
5.修改Service实现类代码
只是本人学习所记笔记,并非本人所属!
__EOF__

本文链接:https://www.cnblogs.com/cxd424/p/14946314.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构