谈谈mybatis的理解(一)

mybatis不允许方法的重载,因为ID不能重复

mybatis

为什么要使用mybatis?

JDBC的弊端

硬编码:SQL语句存在Java代码中,不能很好的分离数据库语句和Java语句,造成代码不易维护

代码重复度高:大量重复的代码

SQL参数固定 :SQL语句的参数固定,使得SQL语句不灵活,无法满足多变的场景

底层技术:JDBC属于底层的技术,不支持分布式,缓存等技术,对于复杂场景的应对不好

ORM模型:ORM 模型是数据库的表和简单 Java 对象(Plain Ordinary Java Object,简称 POJO)的映射关系模型,主要解决数据库数据和 POJO 对象的相互映射

java类和数据库的映射关系:

java类 数据库表
属性 字段

常见的ORM模型

  1. Hibernate :Hibernate 是一个 全自动 的 ORM 模型,Hibernate 可以自动生成 SQL 语句,自动执行
  2. MyBatis :MyBatis 是一款 半自动 的 ORM 模型,它支持定制化 SQL、存储过程以及高级映射
Mybatis的映射器
select元素

语法规则:< select 属性="值">查询类SQL语句</ select >

属性 说明
id 唯一标识,和接口中的方法名一致
parameterType 参数的类型(入参)
resultType 结果的类型
resultMap 复杂的结果集映射关系

注意:小于号<需要使用转义字符进行代替 <

insert元素

语法规则:< insert 属性="值">新增类SQL语句</ insert >

注意:新增可以添加主键回调

属性 说明
keyProperty 表示以哪个列作为属性的主键,不能和 keyColumn 同时使用
keyColumn 指明哪一列是主键,不能和 keyProperty 同时使用
useGeneratedKeys 使用 JDBC 的 getGeneratedKeys 方式来取有数据库内部生成的主键

主键回调:当主键在数据库中为自增字段时,新增成功后,回调主键

java 复制代码
<insert id="addStudent" parameterType="Student" keyProperty="sid"useGeneratedKeys="true">
	 	insert into student(sname,birthday,ssex,classid)
	 	values(#{sname},#{birthday},#{ssex},#{classid})
</insert>

update元素

语法规则:< update 属性="值">查询类SQL语句</ update >

java 复制代码
<update id="updateStudent" parameterType="Student">
	 	update student set sname=#{sname},birthday=#{birthday},ssex = #{ssex},
	 	classid = #{classid} where sid = #{sid}	 
</update>

delete元素

语法规则:< delete 属性="值">查询类SQL语句</ delete >

java 复制代码
<delete id="delStudent" parameterType="int">
	 	delete from student where sid = #{v}
</delete>

resultMap元素

为什么要使用 resultMap 元素?

因为数据库的字段名和java的属性名不一致

存储映射结果集

type表示需要映射的实体类,id是resultMap的唯一标识

属性 说明
column 对应数据库中的字段名
property 要映射到实体类的属性名
java 复制代码
<resultMap type="Student" id="stu_class_Map">
		<result column="sid" property="sid"/>
		<result column="sname" property="sname"/>
		<result column="birthday" property="birthday"/>
		<result column="ssex" property="ssex"/>
		<result column="classid" property="classid"/>
</resultMap>

<select id="findAllStudentAndClass" resultMap="stu_class_Map">
		select * from Student 
</select>

多表联查

什么是级联:级联(cascade),是指多个对象之间的映射关系,建立数据之间的级联关系提高管理效率

一对一级联

一对一使用association

java 复制代码
	<resultMap type="Student" id="stu_class_Map">
		<result column="sid" property="sid"/>
		<result column="sname" property="sname"/>
		<result column="birthday" property="birthday"/>
		<result column="ssex" property="ssex"/>
		<result column="classid" property="classid"/>
		<!-- 一对一 -->
		<association property="bj">
			<result column="classid" property="classid" />
			<result column="classname" property="classname"/>
		</association>
	</resultMap>

	<select id="findAllStudentAndClass"  resultMap="stu_class_Map" >
		select * from student 
		left join class on student.classid = class.classid
	</select>

在多表联查中没有显示映射的字段不会被赋值

一对多级联

一对多使用collection

java 复制代码
	<resultMap type="Banji" id="bj_stu_Map">
		<result column="classid" property="classid" />
		<result column="classname" property="classname" />
		
		<!-- 一对多  -->
		<collection property="slist" ofType="Student">
			<result column="sid" property="sid"/>
			<result column="sname" property="sname"/>
			<result column="birthday" property="birthday"/>
			<result column="ssex" property="ssex"/>
			<result column="classid" property="classid"/>
		</collection>

	</resultMap>

	<select id="findAllBanjiAndStu" resultMap="bj_stu_Map">
		select * from class left join student on class.classid = student.classid
	</select>

一对多联查的步骤:

  1. 创建"一"方实体类(以集合的形式级联"多"方对象)
  2. 创建"多"方对象(创建"多"方的实体类)
  3. 创建映射器
  4. 实现一对多级联(利用collection元素实现一对多的级联)
相关推荐
NE_STOP7 分钟前
SpringBoot-shiro-jwt-dubbo-redis分布式统一权限系统(完结)
java
zfj32112 分钟前
java函数式接口 @FunctionalInterface用法
java·函数·function
TracyCoder12318 分钟前
并发编程(二):Java原子类(Atomic Classes)全解析
java·原子类·atomic
野犬寒鸦29 分钟前
从零起步学习MySQL || 第十六章:MySQL 分库分表的考量策略
java·服务器·数据库·后端·mysql
木风小助理39 分钟前
JavaAtomicInteger底层实现深度解析
java
BD_Marathon1 小时前
搭建MyBatis框架之创建MyBatis的映射文件(五)
java·数据库·mybatis
一只叫煤球的猫1 小时前
为什么Java里面,Service 层不直接返回 Result 对象?
java·spring boot·面试
洛阳泰山1 小时前
智能体项目MaxKB4J - 本地部署与开发完整指南
java·agent·工作流·rag·智能体·maxkb
Solar20251 小时前
机械制造业TOB企业获客软件选型指南:从挑战到解决方案的深度解析
java·大数据·服务器·架构·云计算
星火开发设计1 小时前
C++ stack 全面解析与实战指南
java·数据结构·c++·学习·rpc··知识