mybatis不允许方法的重载,因为ID不能重复
mybatis
为什么要使用mybatis?
JDBC的弊端:
硬编码:SQL语句存在Java代码中,不能很好的分离数据库语句和Java语句,造成代码不易维护
代码重复度高:大量重复的代码
SQL参数固定 :SQL语句的参数固定,使得SQL语句不灵活,无法满足多变的场景
底层技术:JDBC属于底层的技术,不支持分布式,缓存等技术,对于复杂场景的应对不好
ORM模型:ORM 模型是数据库的表和简单 Java 对象(Plain Ordinary Java Object,简称 POJO)的映射关系模型,主要解决数据库数据和 POJO 对象的相互映射
java类和数据库的映射关系:
java类 | 数据库表 |
---|---|
属性 | 字段 |
常见的ORM模型
- Hibernate :Hibernate 是一个 全自动 的 ORM 模型,Hibernate 可以自动生成 SQL 语句,自动执行
- 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>
一对多联查的步骤:
- 创建"一"方实体类(以集合的形式级联"多"方对象)
- 创建"多"方对象(创建"多"方的实体类)
- 创建映射器
- 实现一对多级联(利用collection元素实现一对多的级联)