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元素
语法规则:查询类SQL语句 select >
属性 | 说明 |
---|---|
id | 唯一标识,和接口中的方法名一致 |
parameterType | 参数的类型(入参)服务器托管网 |
resultType | 结果的类型 |
resultMap | 复杂的结果集映射关系 |
注意:小于号
insert元素
语法规则:新增类SQL语句 insert >
注意:新增可以添加主键回调
属性 | 说明 |
---|---|
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元素
语法规则:查询类SQL语句 update >
update id="updateStudent" parameterType="Student">
update student set sname=#{sname},birthday=#{birthday},ssex = #{ssex},
classid = #{classid} where sid = #{sid}
/update>
delete元素
语法规则:查询类SQL语句 delete >
delete id="delStudent" parameterType="int">
delete from student where sid = #{v}
/delete>
re服务器托管网sultMap元素
为什么要使用 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>
一对多联查的步骤:
- 创建“一”方实体类(以集合的形式级联“多”方对象)
- 创建“多”方对象(创建“多”方的实体类)
- 创建映射器
- 实现一对多级联(利用collection元素实现一对多的级联)
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
相关推荐: 新手能掌握 PyTorch 的填充技术:深入理解反射、复制、零值和常数填充
目录 torch.nn子模块详解 nn.ReflectionPad1d 参数说明: 形状(Shape): 使用示例: 注意事项: nn.ReflectionPad2d 参数说明: 形状(Shape): 使用示例: 注意事项: nn.ReflectionPad3…