声明:本文大多数借鉴于网络,如有雷同,望见谅!!!
1:传统的jdbc相对于mybatis的弊端
传统的jdbc代码操作量大,操作数据库至少要5步
(1)导入sql相关的包、
(2)注册MySQL驱动
(3)获取一个连接
(4)创建一个查询
(5)从resultSet中获取数据并转化成bean
(6)关闭连接
业务代码和技术代码耦合
连接资源手动关闭,带来了隐患
2:ORM是什么?
对象关系映射(ORM Obeject Relational Mapping),ORM模型就是数据库的表与简单Java对象(POJO)的映射模型,它主要解决数据库数据和POJO对象的相互映射
ORM带来的好处
更加贴合面向对象的编程语意
技术和业务解耦,Java程序员无需对数据库相关的知识深入了解
不用担心没有释放数据库连接资源了
3:ORM框架两大霸主
4:Mybatis是什么?
Mybatis前身是iBatis,其源于“Internet”和“ibatis”的组合,本质是一种半自动的ORM框架,除了POJO和映射关系之外,还需要编写SQL语句
Mybatis映射文件三要素: SQL 映射规则(xml文件) POJO 对象(Java实体类)
5:Mybatis四种生命周期
SqlSessionFactoryBuilder:读取配置信息创建SqlSessionFactory,建造者模式,方法级别生命周期
SqlSessionFactory:创建Sqlsession,工厂单例模式,存在于程序的整个生命周期;
SqlSession:代表一次数据库连接,可以直接发送SQL执行,也可以通过调用Mapper访问数据库;线程不安全,要保证线程独享(方法级)
sql Mapper:由一个Java接口和XML文件组成,包含了要执行的SQL语句和结果集映射规则。方法级别生命周期
6:Mybatis配置
mybatis-config.xml配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<properties resource="db.properties" />
<setting name="mapUnderscoreToCamelCase" value="true" />
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="UNPOOLED">
<property name="driver" value="${jdbc_driver}" />
<property name="url" value="${jdbc_url}" />
<property name="username" value="${jdbc_username}" />
<property name="password" value="${jdbc_password}" />
<mapper class="com.enjoylearning.mybatis.mapper.TUserMapper" />
</configuration>
7:Mybatis配置 setting
8:Mybatis配置 environments
(1)environment元素是配置一个数据源的开始,属性id是它的唯一标识
(2)transactionManager 元素配置数据库事务,其中type属性有三种配置方式
jdbc,采用jdbc的方式管理事务;
managed,采用容器的方式管理事务,在JNDI数据源中使用;
自定义,自定义数据库事务管理办法;
(3)dataSource 元素配置数据源连接信息,type属性是连接数据库的方式配置,有四种配置方式
UNPOOLED 非连接池方式连接
POOLED 使用连接池连接
JNDI 使用JNDI数据源
自定义数据源
9:Mybatis配置 mapper
(1)用classPath下资源引用
(2)用类注册方式引用
(3)使用包名引入引射器名
第一种方式推荐使用,类文件和mapper文件可以不需要放在一个文件夹中,xml文件也不会和java文件混合在一起
10:基于xml配置的映射器
11:select元素
(1)自动映射
前提:SQL列名和JavaBean的属性是一致的;
自动映射等级autoMappingBehavior设置为PARTIAL,需要谨慎使用FULL;
使resultType;
如果列名和JavaBean不一致,但列名符合单词下划线分割,Java是驼峰命名法,则mapUnderscoreToCamelCase可设置为true;
(2)传递多个查询入参
使用map传递参数;可读性差,导致可维护性和可扩展性差,杜绝使用;
使用注解传递参数;直观明了,当参数较少一般小于5个的时候,建议使用;
使用Java Bean的方式传递参数;当参数大于5个的时候,建议使用;
12:resultMap元素属性
resultMap 元素是MyBatis 中最重要最强大的元素。它可以让你从90% 的 JDBCResultSets 数据提取代码中解放出来,在对复杂语句进行联合映射的时候,它很可能可以代替数千行的同等功能的代码。
resultMap 的设计思想是,简单的语句不需要明确的结果映射,而复杂一点的语句只需要描述它们的关系就行了
resultMap元素子元素
constructor- 用于在实例化类时,注入结果到构造方法中
•idArg - ID 参数;标记出作为 ID 的结果可以帮助提高整体性能
•arg - 将被注入到构造方法的一个普通结果
id – 一个 ID 结果;标记出作为 ID 的结果可以帮助提高整体性能
result – 注入到字段或 JavaBean 属性的普通结果
association– 一个复杂类型的关联;许多结果将包装成这种类型
•嵌套结果映射 – 关联可以指定为一个 resultMap 元素,或者引用一个
collection– 一个复杂类型的集合
•嵌套结果映射 – 集合可以指定为一个 resultMap 元素,或者引用一个
discriminator– 使用结果值来决定使用哪个resultMap
•case – 基于某些值的结果映射
°嵌套结果映射 – 一个 case 也是一个映射它本身的结果,因此可以包含很多相 同的元素,或者它可以参照一个外部的 resultMap
13:id& result
id和 result 都将一个列的值映射到一个简单数据类型(字符串,整型,双精度浮点数,日期等)的属性或字段
两者之间的唯一不同是,id 表示的结果将是对象的标识属性,这会在比较对象实例时用到。
这样可以提高整体的性能,尤其是缓存和嵌套结果映射(也就是联合映射)的时候
14:constructor
一个pojo不存在没有参数的构造方法,就需要使用constructor;
为了通过名称来引用构造方法参数,你可以添加 @Param注解,指定参数名称的前提下,以任意顺序编写 arg 元素
15:insert,update 和delete
16:selectKey元素(仅对insert和update有用)
<insert id="insert2" parameterType="TUser">
<selectKey keyProperty="id" order="AFTER" resultType="int">
select LAST_INSERT_ID()
insert into t_user (id, user_name, real_name,
sex, mobile,
email,
note, position_id)
values (#{id,jdbcType=INTEGER},
#{userName,jdbcType=VARCHAR},
#{realName,jdbcType=VARCHAR},
#{sex,jdbcType=TINYINT}, #{mobile,jdbcType=VARCHAR},
#{email,jdbcType=VARCHAR},
#{note,jdbcType=VARCHAR},
#{positionId,jdbcType=INTEGER})
</insert>
17:sql元素和参数
sql元素:用来定义可重用的 SQL 代码段,可以包含在其他语句中
参数:向sql语句中传递的可变参数
预编译 #{}:将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号,能够很大程度防止sql注入;
传值 ${}:传入的数据直接显示生成在sql中,无法防止sql注入;
表名、选取的列是动态的,order by和in操作, 可以考虑使用$
18:注解方式配置
注解方式就是将SQL语句直接写在接口上,对于需求比较简单的系统,效率较高。缺点在于,每次修改sql语句都要编译代码,对于复杂的sql语句可编辑性和可读性都差,一般不建议使用这种配置方式;
@Select @Results @Insert @Update @Delete
19:动态sql元素
trim用法
<insert id="insertSelective" parameterType="TUser">
insert into t_user
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null">
id,
<if test="userName != null">
user_name,
<if test="realName != null">
real_name,
<if test="sex != null">
sex,
<if test="mobile != null">
mobile,
<if test="email != null">
email,
<if test="note != null">
note,
<if test="positionId != null">
position_id,
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null">
#{id,jdbcType=INTEGER},
<if test="userName != null">
#{userName,jdbcType=VARCHAR},
<if test="realName != null">
#{realName,jdbcType=VARCHAR},
<if test="sex != null">
#{sex,jdbcType=TINYINT},
<if test="mobile != null">
#{mobile,jdbcType=VARCHAR},
<if test="email != null">
#{email,jdbcType=VARCHAR},
<if test="note != null">
#{note,jdbcType=VARCHAR},
<if test="positionId != null">
#{positionId,jdbcType=INTEGER},
</insert>
20:批量操作
(1)通过foreach动态拼装SQL语句
<insert id="insertForeach4Batch">
insert into t_user (user_name, real_name,
sex, mobile,email,note, position_id)
values
<foreach collection="list" separator="," item="user">
(
#{user.userName,jdbcType=VARCHAR},
#{user.realName,jdbcType=VARCHAR},
#{user.sex,jdbcType=TINYINT},
#{user.mobile,jdbcType=VARCHAR},
#{user.email,jdbcType=VARCHAR},
#{user.note,jdbcType=VARCHAR},
#{user.positionId,jdbcType=INTEGER}
)
</insert>
(2)使用BATCH类型的excutor