谈谈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元素实现一对多的级联)
相关推荐
小王师傅664 小时前
【轻松入门SpringBoot】actuator健康检查(上)
java·spring boot·后端
醒过来摸鱼4 小时前
Java classloader
java·开发语言·python
专注于大数据技术栈4 小时前
java学习--StringBuilder
java·学习
loosenivy4 小时前
企业银行账户归属地查询接口如何用Java调用
java·企业银行账户归属地·企业账户查询接口·企业银行账户查询
IT 行者5 小时前
Spring Security 6.x 迁移到 7.0 的完整步骤
java·spring·oauth2
JIngJaneIL5 小时前
基于java+ vue农产投入线上管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
东东的脑洞5 小时前
【面试突击二】JAVA基础知识-volatile、synchronized与ReentrantLock深度对比
java·面试
川贝枇杷膏cbppg5 小时前
Redis 的 AOF
java·数据库·redis
吃喝不愁霸王餐APP开发者6 小时前
Java后端系统对接第三方外卖API时的幂等性设计与重试策略实践
java·开发语言
TG:@yunlaoda360 云老大6 小时前
华为云国际站代理商的CBR主要有什么作用呢?
java·网络·华为云