谈谈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语句

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

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

insert元素

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

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

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

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

<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 id="updateStudent" parameterType="Student">
	 	update student set sname=#{sname},birthday=#{birthday},ssex = #{ssex},
	 	classid = #{classid} where sid = #{sid}	 
</update>

delete元素

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

<delete id="delStudent" parameterType="int">
	 	delete from student where sid = #{v}
</delete>

resultMap元素

为什么要使用 resultMap 元素?

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

存储映射结果集

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

属性 说明
column 对应数据库中的字段名
property 要映射到实体类的属性名
<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

	<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

	<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元素实现一对多的级联)

你可能感兴趣的:(java,mybatis,java)