Day10--mybatis多表连接查询学习(一对一、一对多、多对多)

MyBatis是一个优秀的持久层框架,支持将SQL语句、存储过程以及高级映射转换成Java对象。下面是MyBatis处理一对一、一对多、多对多关系的方式及相应的代码示例。

数据库表

假设有四个表:userordersroleuser_role---->创建代码(占位较长)放在文章末尾···
首先先了解对应关系:
一对一:1订单对应1用户
一对多:1用户对应多订单
多对多:一个用户对应多种角色,一种角色对应多个用户

Java实体类(一表一数据库标准)

public class Orders {private Integer id;private Date ordertime;private Double total;//将user表注入order表(一对一)private User user;// getters and setters}public class Role {private Integer id;private String roleName;private String roleDesc;// getters and setters}public class User {private Integer id;private String username;private String password;// 关于时间的转换处理,这里采用一个工具类在mybatis_config中配置好后隐式调用实现,代码文章末尾给出// 数据库中时间的储存是bigint在Java中是dateprivate Date birthday;//将order表中数据注入user,类型为ArrayList<User>(一对多)private ArrayList<User> ordersArrayList;//将role表中数据注入user,类型为ArrayList<Role>(多对多)private ArrayList<Role> rolesArrayList;// getters and setters}
public class User_role {private Integer userId;private Integer roleId;// getters and setters

本次都采用XML独立映射文件来执行查询语句具体如下:

Mapper接口

import java.util.ArrayList;
public interface Mapper {//    一对一ArrayList<Orders> selectOrderUser();//    一对多ArrayList<User> selectUserOrders();//    多对多ArrayList<User> selectInfoRole();
}

Mapper.XML映射文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--接口代理映射,Mapper接口-->
<mapper namespace="Day10.Mapper"><!--数据库的一对一查询++++注意:association+++javaType--><select id="selectOrderUser" resultMap="oTo">select *, o.id oidfrom orders o,user uwhere o.uuid = u.id</select><resultMap id="oTo" type="Day10.Model.Orders"><!--手动去指定字段与实体属性的映射关系--><!--            column: 数据表的字段名称--><!--            property: 实体属性的名称--><id column="oid" property="id"></id><result column="ordertime" property="ordertime"></result><result column="total" property="total"></result><!--            property: 当前实体(order)中的属性名称(private User user)--><!--            javaType: 当前实体(order)中的属性类型(User)--><association property="user" javaType="Day10.Model.User"><id column="uuid" property="id"></id><result column="username" property="username"></result><result column="password" property="password"></result><result column="birthday" property="birthday"></result></association></resultMap><!--数据库的一对多查询++++注意:collection+++ofTyp--><select id="selectUserOrders" resultMap="oTm">select *, o.id oidfrom user u,orders owhere o.uuid = u.id</select><resultMap id="oTm" type="Day10.Model.User"><id column="uuid" property="id"></id><result column="username" property="username"></result><result column="password" property="password"></result><result column="birthday" property="birthday"></result><collection property="ordersArrayList" ofType="Day10.Model.Orders"><id column="oid" property="id"></id><result column="ordertime" property="ordertime"></result><result column="total" property="total"></result></collection></resultMap><!--数据库的多对多查询++++注意:collection+++ofType--><select id="selectInfoRole" resultMap="mTm">select *from role r,user_role ur,user uwhere ur.userId = u.idand ur.roleId = r.id</select><resultMap id="mTm" type="Day10.Model.User"><id column="userId" property="id"></id><result column="username" property="username"></result><result column="password" property="password"></result><result column="birthday" property="birthday"></result><collection property="rolesArrayList" ofType="Day10.Model.Role"><id column="roleId" property="id"></id><result column="roelName" property="roleName"></result><result column="roleDesc" property="roleDesc"></result></collection></resultMap>
</mapper>

mybatis_config.xml配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><settings><setting name="logImpl" value="LOG4J"/></settings><!-- 处理日期转换隐式调用--><typeHandlers><typeHandler handler="Day10.DateTypeHandler"></typeHandler></typeHandlers><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/mts?serverTimezone=UTC"/><property name="username" value="root"/><property name="password" value="123456"/></dataSource></environment></environments><mappers>
<!--        这里的写的是mapper映射文件--><mapper resource="mybatis/mappers/mts/Mapper.xml"/></mappers>
</configuration>

调用测试

import Day10.Model.Orders;
import Day10.Model.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.apache.log4j.PropertyConfigurator;import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Properties;public class Dao {public static SqlSession session;public static Mapper mapper;static {try {session = getSession();mapper = session.getMapper(Mapper.class);} catch (IOException e) {throw new RuntimeException(e);}}public static SqlSession getSession() throws IOException {InputStream in = Resources.getResourceAsStream("mybatis/config/mybatis_config_mts.xml");SqlSessionFactory fac = new SqlSessionFactoryBuilder().build(in);SqlSession sqlSession = fac.openSession();return sqlSession;}public static void logOut() throws IOException {Properties properties = new Properties();FileInputStream in = new FileInputStream("src/resources/log4j.properties");properties.load(in);PropertyConfigurator.configure(properties);}public static void main(String[] args) {ArrayList<Orders> orders = mapper.selectOrderUser();for (Orders o : orders) {System.out.println(o);}ArrayList<User> users = mapper.selectUserOrders();for (User user : users) {System.out.println(user);}ArrayList<User> users1 = mapper.selectInfoRole();for (User user : users1) {System.out.println(user);}}
}

通过上述例子,我们可以看到MyBatis通过resultMapassociationcollection等标签来实现复杂的数据库关系映射,简化了SQL查询和Java对象之间的转换。
结尾线

数据库表创建代码

CREATE TABLE `user` (`id` int NOT NULL AUTO_INCREMENT COMMENT '用户ID',`username` varchar(50) NOT NULL COMMENT '用户名',`password` varchar(50) NOT NULL COMMENT '密码',`birthday` bigint NOT NULL COMMENT '生日',PRIMARY KEY (`id`)
);
INSERT INTO `user` VALUES ('1', 'aa', '1233', '20221213');
INSERT INTO `user` VALUES ('2', 'bb', '2133', '20211212');
INSERT INTO `user` VALUES ('3', 'cc', '2133', '10211212');
INSERT INTO `user` VALUES ('4', 'xx', '12343', '20111213');
INSERT INTO `user` VALUES ('5', 'yy', '12343', '20111213');CREATE TABLE `orders` (`id` int NOT NULL AUTO_INCREMENT COMMENT '订单ID',`ordertime` bigint NOT NULL,`total` double NOT NULL COMMENT '总共订单数量',`uuid` int NOT NULL COMMENT '用户的ID',PRIMARY KEY (`id`),KEY `user_orders` (`uuid`),CONSTRAINT `user_orders` FOREIGN KEY (`uuid`) REFERENCES `user` (`id`)
);
INSERT INTO `orders` VALUES ('1', '20211112', '12.5', '1');
INSERT INTO `orders` VALUES ('2', '20211115', '12.5', '3');
INSERT INTO `orders` VALUES ('3', '20311115', '12.5', '2');
INSERT INTO `orders` VALUES ('4', '20221213', '15', '2');
INSERT INTO `orders` VALUES ('5', '20221212', '15', '1');CREATE TABLE `role` (`id` int NOT NULL AUTO_INCREMENT COMMENT '角色ID',`roleName` varchar(50) NOT NULL COMMENT '角色名称',`roleDesc` varchar(100) NOT NULL COMMENT '角色的描述',PRIMARY KEY (`id`)
);
INSERT INTO `role` VALUES ('1', '商家', '负责卖商品的商家');
INSERT INTO `role` VALUES ('2', '买家', '负责买商品的顾客');
INSERT INTO `role` VALUES ('3', '管理员', '负责商品的管理问题');CREATE TABLE `user_role` (`userId` int NOT NULL COMMENT '用户id',`roleId` int NOT NULL COMMENT '角色id',KEY `user_userId` (`userId`),KEY `role_roleId` (`roleId`),CONSTRAINT `role_roleId` FOREIGN KEY (`roleId`) REFERENCES `role` (`id`),CONSTRAINT `user_userId` FOREIGN KEY (`userId`) REFERENCES `user` (`id`)
);
INSERT INTO `user_role` VALUES ('1', '2');
INSERT INTO `user_role` VALUES ('2', '1');
INSERT INTO `user_role` VALUES ('3', '1');

时间转换工具类(直接复制粘贴使用就好)

package Day10;import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Date;public class DateTypeHandler extends BaseTypeHandler<Date> {// 将java类型转换成数据库需要的类型@Overridepublic void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType jdbcType) throws SQLException {long time = date.getTime();preparedStatement.setLong(i, time);}// 将数据库中的类型 转换为java类型
// string 要转换的字符串
// resultSet 查询出的结果@Overridepublic Date getNullableResult(ResultSet resultSet, String s) throws SQLException {
// 获得结果中需要的数据(long) 转换为Date类型long along = resultSet.getLong(s);Date date = new Date(along);return date;}// 将数据库中的类型 转换为java类型@Overridepublic Date getNullableResult(ResultSet resultSet, int i) throws SQLException {long along = resultSet.getLong(i);Date date = new Date(along);return date;}// 将数据库中的类型 转换为java类型@Overridepublic Date getNullableResult(CallableStatement callableStatement, int i) throws SQLException {long aLong = callableStatement.getLong(i);Date date = new Date(aLong);return date;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/387662.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Qt开发】No matching signal for on_toolButton_clicked() 解决方案

【Qt开发】No matching signal for on_toolButton_clicked() 解决方案 文章目录 No matching signal for xxx 解决方案附录&#xff1a;C语言到C的入门知识点&#xff08;主要适用于C语言精通到Qt的C开发入门&#xff09;C语言与C的不同C中写C语言代码C语言到C的知识点Qt开发中…

企业级Linux系统防护

一、企业级Linux系统防护概述 一&#xff09;企业级Linux系统安全威胁 企业级Linux系统安全威胁列表 解决的主要安全威胁安全威胁牵涉到的人员及操作文件系统防护避免有意/无意的文件篡改、越权访问&#xff0c;根用户&#xff08;root&#xff09;权限泛滥企业内部用户误操作、…

UPLOAD-LABS靶场[超详细通关教程,通关攻略]

---------------------------------------- 靶场环境&#xff1a; 下载链接&#xff1a; https://codeload.github.com/c0ny1/upload-labs/zip/refs/heads/master 使用小皮集成环境来完成这个靶场 将文件放到WWW目录下就可以进行访问 ------------------------------------…

CTF-Web习题:[GXYCTF2019]Ping Ping Ping

题目链接&#xff1a;[GXYCTF2019]Ping Ping Ping 解题思路 访问靶机&#xff0c;得到如下页面&#xff0c;类似于URL参数 尝试用HackBar构造url传输过去看看 发现返回了ping命令的执行结果&#xff0c;可以猜测php脚本命令是ping -c 4 $ip&#xff0c;暂时不知道执行的函数…

学习Numpy的奇思妙想

学习Numpy的奇思妙想 本文主要想记录一下&#xff0c;学习 numpy 过程中的偶然的灵感&#xff0c;并记录一下知识框架。 推荐资源&#xff1a;https://numpy.org/doc/stable/user/absolute_beginners.html &#x1f4a1;灵感 为什么 numpy 数组的 shape 和 pytorch 是 tensor 是…

Ribbon负载均衡与内核原理

什么是Ribbon? 目前主流的负载方案分为两种&#xff1a; 集中式负载均衡&#xff0c;在消费者和服务提供方中间使用独立的代理方式进行负载&#xff0c;有硬件的&#xff08;比如F5&#xff09;&#xff0c;也有软件的&#xff08;Nginx&#xff09;客户端根据自己的请求做负…

FFmpeg研究

1.FFmpeg介绍 FFmpeg的全称是“Fast Forward Moving Picture Expert Group”&#xff0c;组件由命令行应用程序和函数库两部分组成。通俗概括来说&#xff0c;FFmpeg 是一个免费的开源程序库&#xff0c;一个多媒体音视频处理分析工具软件&#xff0c;且提供命令行方式调用&am…

C语言笔记38 •数据结构--队列•

数据结构--队列 1.队列的定义 队列&#xff1a;只允许在一端进行插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff0c;队列具有 先 进先出 FIFO(First In First Out). 入队列&#xff1a;进行插入操作的一端称为 队尾 出队列&#xff1a;进行删除操作的…

Jmeter混合压测(2407)

一 压测需求&#xff1a; 电商作为服务端&#xff0c;至少需要满足并发量,QPS:100/s,TPS:20/s。例如场景&#xff1a; 电商交易中&#xff0c;商品图片请求量最多&#xff0c;电商服务端需要满足并发请求查询图片信息。各家可能会并发请求同一家电商商品、订单等内容。 二 压…

基于多种机器学习算法的短信垃圾分类模型

文章目录 有需要本项目的代码或文档以及全部资源&#xff0c;或者部署调试可以私信博主导入第三方库读取数据数据预处理数据分析与可视化机器学习建模贝叶斯逻辑回归支持向量机随机森林XGBoost总结每文一语 有需要本项目的代码或文档以及全部资源&#xff0c;或者部署调试可以私…

redis集群三种模式

redis 集群 高可用 redis集群三种模式 主从复制 奇数台 3 一主两从 哨兵模式 3 一主两从 cluser 集群 6 3 3 3 9 主从复制&#xff1a;和mysql的主从复制类似&#xff0c;写入主的数据通过rdb方式把数据同步到从服务器。从不能更新到主&#xff0c;…

未来不会使用 AI 的人真的会被淘汰吗?

AI 是今年大火的一个话题&#xff0c;随着 ChatGPT 之类的一系列大模型开始流行以后&#xff0c;有不少的培训机构宣称这样的口号: “未来不会使用 AI 的人将会被淘汰”。我觉得这个观点本身并没有错&#xff0c;但是关键在于那些培训机构出于自身的利益&#xff0c;故意忽略了…

内存问题检测

内存检测方式 gcc/g 内存检测方式如下&#xff0c;添加一些编译标签&#xff1a; -fsanitizeleak 检测内存泄漏。例如添加标签&#xff1a;-fsanitizeleak -g -O0-fsanitizeaddress 检测内存越界。例如添加标签&#xff1a;-fsanitizeaddress -g -O2&#xff0c;优化级别开…

02 I/O多路复用---进程的聊天

服务器同时和很多客户端连在一起 管道的read&#xff0c;总是能读出来

前后端分离开发遵循接口规范-YAPI

目前&#xff0c;网站主流开发方式是前后端分离。因此前后端必须遵循一套统一的规范&#xff0c;才能保证前后端进行正常的数据&#xff08;JSON数据格式&#xff09;请求、影响&#xff0c;这套规范即是 YAPI. 产品经理撰写原型&#xff1b; 前端或后端撰写接口文档。 YAPI…

Android高级interview

一、Android基础知识 1、四大组件、六大布局、五大存储 四大组件&#xff1a; activity、service、content provider、broadcast六大布局&#xff08;现在是 7 大了&#xff09;: 线性布局&#xff08;LinearLayout&#xff09;相对布局&#xff08;RelativeLayout&#xf…

替换后端国外身份目录服务,宁盾身份域管接管FileNet助力国产化升级

IBM FileNet 是一款优秀的企业内容管理解决方案&#xff0c;为客户提供了领先的文档管理和流程管理集成环境&#xff0c;被大量企业所采用。FileNet 需要使用企业级的目录服务器&#xff08;LDAP&#xff09;作为其用户管理系统&#xff0c;满足其认证和授权的需求。对于 LDAP …

成为git砖家(4): git status 命令简介

1. untracked 和 tracked 状态 Remember that each file in your working directory can be in one of two states: tracked or untracked. Tracked files are files that were in the last snapshot, as well as any newly staged files; they can be unmodified, modified, o…

zabbix使用脚本自定义监控项

1. 在zabbix_agent的配置文件中配置自定义key和脚本位置 vim /etc/zabbix/zabbix_agentd.confUserParametermq_check_log,/etc/zabbix/zabbix_agentd.d/mqlog.shmq_check_log&#xff1a;是这个自定义参数的名称。在Zabbix的监控项&#xff08;item&#xff09;配置中&#xf…

点菜吧——随便点 C#生成套餐

前言 一到食堂发现有多种选择&#xff0c;但是有一个固定的套路&#xff0c;只能是一个荤&#xff0c;二个小荤&#xff0c;菜品数量也不少&#xff0c;任君选择&#xff0c;如果是一个选择困难症&#xff0c;就有点烦了&#xff0c;所以出品这个自动生成套餐软件。各位老板可…