MyBatis多表操作查询功能怎么用
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,小编给大家分享一下MyBatis多表操作查询功能怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一对一查询用户表和订单表的关系为,一个用户多个订单,一个订单只从属一个用户一对一查
千家信息网最后更新 2025年11月07日MyBatis多表操作查询功能怎么用
小编给大家分享一下MyBatis多表操作查询功能怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
一对一查询
用户表和订单表的关系为,一个用户多个订单,一个订单只从属一个用户
一对一查询的需求:查询一个订单,与此同时查询出该订单所属的用户
在只查询order表的时候,也要查询user表,所以需要将所有数据全部查出进行封装SELECT *,o.id oid FROM orders o,USER u WHERE o.uid=u.id
创建Order和User实体
order
public class Order { private int id; private Date ordertime; private double total; //表示当前订单属于哪一个用户 private User user;user
public class User { private int id; private String username; private String password; private Date birthday;创建OrderMapper接口
public interface UserMapper {//查询全部的方法 public List findAll();} 配置OrderMapper.xml
sqlMapConfig.xml
在一对一配置的时候,在order实体中创建了一个user,所以property属性都使用user.** 的方式进行编写,但是这里还可以使用association
一对多查询的模型
用户表和订单表的关系为,一个用户有多个订单,一个当但只从属一个用户
一对多查询需求:查询一个用户,与此同时查询出该用户具有的订单
package com.zg.domain;import java.util.Date;import java.util.List;public class User { private int id; private String username; private String password; private Date birthday; //描述当前用户存在哪些订单 private List orderList; public List getOrderList() { return orderList; } public void setOrderList(List orderList) { this.orderList = orderList; } @Override public String toString() { return "User{" + "id=" + id + ", username='" + username + '\'' + ", password='" + password + '\'' + ", birthday=" + birthday + ", orderList=" + orderList + '}'; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; }} 修改User实体
package com.zg.domain;import java.util.Date;import java.util.List;public class User { private int id; private String username; private String password; private Date birthday; //描述当前用户存在哪些订单 private List orderList; public List getOrderList() { return orderList; } public void setOrderList(List orderList) { this.orderList = orderList; } @Override public String toString() { return "User{" + "id=" + id + ", username='" + username + '\'' + ", password='" + password + '\'' + ", birthday=" + birthday + ", orderList=" + orderList + '}'; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; }} 创建UserMapper接口
package com.zg.mapper;import com.zg.domain.User;import java.util.List;public interface UserMapper { public List findAll();} 配置UserMapper.xml
测试
@Test//测试一对多 public void test2() throws IOException { InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream); SqlSession sqlSession = sqlSessionFactory.openSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); List userList = mapper.findAll(); for (User user : userList) { System.out.println(user); } sqlSession.close(); } 多对多查询
用户表和角色表的关系为,一个用户有多个角色,一个角色被多个用户使用
多对多查询的需求:查询用户同时查询该用户的所有角色
select * from user u,sys_user_role ur ,sys_role r where u.id=ur.userId and ur.roleId=r.id
创建Role实体,修改User实体

添加UserMapper接口
package com.zg.mapper;import com.zg.domain.User;import java.util.List;public interface UserMapper { public List findAll(); public List findUserAndRoleAll();} 配置UserMapper.xml
测试代码
@Test//测试多对多 public void test3() throws IOException { InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream); SqlSession sqlSession = sqlSessionFactory.openSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); List userAndRoleAll = mapper.findUserAndRoleAll(); for (User user : userAndRoleAll) { System.out.println(user); } sqlSession.close(); } 看完了这篇文章,相信你对"MyBatis多表操作查询功能怎么用"有了一定的了解,如果想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!
查询
用户
订单
实体
多个
角色
测试
配置
一对一
接口
需求
用户表
功能
查询功能
与此同时
时候
篇文章
从属
代码
同时
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
计算机网络技术教学实施过程
中通吉网络技术有限公司待遇
湖南通信软件开发服务有哪些
护苗青少年网络安全教学视频
苹果总是出现无法验证服务器身份
裸金属服务器安装
DMIT服务器没有响应
网络技术计划教学ppt
数据库技术成绩单excel
emobile7登陆服务器是
和平精英怎么使用第二个服务器
mc里面如何创造服务器
网络安全专业考公
卫生技工二级网络技术述职报告
邮件中间服务器的安全
mc外网服务器搭建
手机服务器中断
打开网页代理服务器错误
公安局强化网络安全管理
安徽农业大学网络技术试卷
网络安全教育 视频
美国访问日本服务器
游戏服务器压测优化
多多出评软件开发
软件开发会不会饱和
怎样把信息打印到数据库中
数据库数据分布函数
平板软件开发工作怎么样
备份数据库操作
荣耀大天使复古服务器