MyBatis多表操作查询功能怎么用
发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,小编给大家分享一下MyBatis多表操作查询功能怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一对一查询用户表和订单表的关系为,一个用户多个订单,一个订单只从属一个用户一对一查
千家信息网最后更新 2025年02月05日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 ListfindAll();}
配置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 ListorderList; 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 ListorderList; 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 ListfindAll();}
配置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); ListuserList = 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 ListfindAll(); 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); ListuserAndRoleAll = mapper.findUserAndRoleAll(); for (User user : userAndRoleAll) { System.out.println(user); } sqlSession.close(); }
看完了这篇文章,相信你对"MyBatis多表操作查询功能怎么用"有了一定的了解,如果想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!
查询
用户
订单
实体
多个
角色
测试
配置
一对一
接口
需求
用户表
功能
查询功能
与此同时
时候
篇文章
从属
代码
同时
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
逻辑磁盘管理器服务器运行失败
dhcp服务器如何配置
对数据库插入百万级数据
手机板我的世界服务器
数据库快捷键y的含义
不能使用宏的数据库类型是
黄石软件开发app制作
网络安全可以在二线城市工作
刷刷乐海南逸鑫网络技术公司
中国信息网络安全网
服务器探针搭建
企业日志审计服务器
各种网络技术实现的功能
服务器管理口什么意思
线程池创建数据库连接
设备故障代码在哪发回服务器
方舟生存进化服务器实况解说
桌面软件开发用编程语言
物业经理管理数据库
佛山游戏软件开发公司
不能使用宏的数据库类型是
我们国家网络安全吗
如何做好民政网络安全
自助终端软件开发平台
果洛软件开发规范
国外网络安全专业硕士就业排名
dcs分散型的数据库
内蒙古绿盟网络安全有限公司
学生网络安全保证书
放心的app软件开发设计