MyBatis多表操作查询功能怎么用
发表于:2024-11-30 作者:千家信息网编辑
千家信息网最后更新 2024年11月30日,小编给大家分享一下MyBatis多表操作查询功能怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一对一查询用户表和订单表的关系为,一个用户多个订单,一个订单只从属一个用户一对一查
千家信息网最后更新 2024年11月30日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安全错误
数据库的锁怎样保障安全
车载网络技术的优点有哪些
服务器开发讲解视频
流媒体服务器软件开发
软件开发条件和限制
公司经营软件开发会计科目
离线模式我的世界怎么进入服务器
i7vpn服务器
软件开发公司的变化趋势
网络技术概论
网络安全法律定罪
长春软件开发招聘
北京品牌软件开发售后保障
macos 安装连不上服务器
文科生搞软件开发
福建服务器电源定制公司
济南龙奥大厦网络安全活动
2020网络安全宣传周试题
机动战士高达ol数据库
itc服务器tts是什么意思
数据库建立视图保证了安全性
服务器换皮肤
迈科集团网络安全项目
杭州轻程网络技术
近来网络安全问题个人信息
邮箱服务器总是访问我的电脑
深化网络安全和信息化工作
倩女幽魂服务器联赛
DNS服务器错误
软件开发培训一般多少钱
long在数据库中怎么表示