1、Mybatis的连接池技术
mybatis 的连接池的分类:
POOLED 使用连接池技术
UNPOOLED 不使用连接池技术
JNDI 使用JNDI实现数据源连接(不经常使用)
设置这些连接池只需要在主配置文件SqlMapConfig.xml的dataSource标签设置type属性即可 如图一所示:
1.1连接池技术原理:
1.2POOLED作用的过程:
2.Mybatis的事务控制:
在mybatis中是通过SqlSession对象的commit方法和rollback方法实现事务的提交和回滚,若手动提交,只需要调用SqlSession对象的commit( )方法即可,若需要自动提交,则在生产SqlSession对象时,在openSession()中传递参数True即可完成自动提交功能,但是不建议自动提交。(底层为调用了JDBC中的setAutoCommit( )方法,默认为false,所以设置为true时即为自动提交)
3.Mybatis中的动态SQL语句:
主要的三个标签<if>、<where>、<foreach>标签
3.1<if>标签:
test的属性值为判断条件,test 属性中写的是对象的属性名,如果是包装类的对象要使用 OGNL 表达式的写法。
另外要注意 where 1=1 的作用(在查询条件数量不确定的条件情况下,使用 where 1=1可以很方便的规范语句,如果不写1=1,那么在每一个不为空的查询条件面前,都必须判断有没有where字句,哪里该加where,哪里该加and/or,用上 where 1=1 之后,就不存在这样的问题, 条件是 and 就直接and ,是or就直接接 or)。
3.2<where>标签:
为了简化上面 where 1=1 的条件拼装,我们可以采用<where>标签来简化开发。
3.3<foreach>标签:
<foreach>标签用于遍历集合
例如:传入多个 id 查询用户信息,用下边两个 sql 实现:
SELECT * FROM USERS WHERE username LIKE '%张%' AND (id =10 OR id =89 OR id=16)
SELECT * FROM USERS WHERE username LIKE '%张%' AND id IN (10,89,16)
这样我们在进行范围查询时,就要将一个集合中的值,作为参数动态添加进来。
这时可以先在 QueryVo 中加入一个 List 集合用于封装参数id,然后定义方法:
于是:
属性:
collection:代表要遍历的集合元素,注意编写时不要写#{}
open:代表语句的开始部分
close:代表结束部分
item:代表遍历集合的每个元素,生成的变量名
sperator:代表分隔符
其中 <include refid="defaultSql"></include> 为引入重复抽取的sql语句,用到了<sql>标签,refid为<sql>标签的id值。
3.4 <sql>标签
<sql>标签抽取重复的sql语句,语句后面不用写分号。
4.mybatis中的多表查询操作:
4.1 一对一查询(多对一查询):
需求:
查询所有账户信息,关联查询下单用户信息。
注意:
因为一个账户信息只能供某个用户使用,所以从查询账户信息出发关联查询用户信息为一对一查询。如
果从用户信息出发查询用户下的账户信息则为一对多查询,因为一个用户可以有多个账户。
方式一:
在Account账户的实体类中,定义对象引用:
IAccountDao接口定义的方法:
在IAccountDao的配置文件中定义对应关系:
SQL语句:
方式二:
定义Account子类的方式实现查询:
如只需要查询账户信息的姓名和地址,那么只需要:
接口中的方法:
SQL语句:
4.2一对一查询(多对一查询):
需求:
查询所有用户信息及用户关联的账户信息。
分析:
用户信息和他的账户信息为一对多关系,并且查询过程中如果用户没有账户信息,此时也要将用户信息
查询出来,我们想到了左外连接查询比较合适
编写的SQL语句:
SELECT u.*,a.id aid,a.uid,a.money FROM user u LEFT JOIN account a ON a.uid = u.id;
因为account表中的id与user表中的id重复,所以将account表的id取别名为aid
在Account账户的实体类中,定义引用:
因为为一对多的关系,一个人可能有多个账户,所以将定义一个List<Account>集合变量。
IUser接口中的方法:
在IUserDao的配置文件中定义对应关系:
*注意:
collection
部分定义了用户关联的账户信息。表示关联查询结果集
property="accounts" :
关联查询的结果集存储在 User 对象的上哪个属性。
ofType="account" :
指定关联查询的结果集中的对象类型即List中的对象类型。此处可以使用别名,也可以使用全限定名。
SQL语句:
5.Mybatis 多表查询之多对多:
5.1实现Role到User的多对多:
用户和角色的关系模型:
需求:
实现查询所有对象并且加载它所分配的用户信息。
分析:
查询角色我们需要用到Role表,但角色分配的用户的信息我们并不能直接找到用户信息,而是要通过中
间表(USER_ROLE 表)才能关联到用户信息。
编写的SQL语句:
SELECT u.*,role.id AS rid,role.`ROLE_DESC`,role.`ROLE_NAME` FROM user AS u LEFT OUTER JOIN user_role ON u.`id`=user_role.`UID` LEFT OUTER JOIN role ON role.`id` = user_role.`RID`;
在User的实体类中,定义多对多的映射:
IUserDao接口中的方法:
在IUserDao的配置文件中定义对应关系:
SQL语句:
5.1实现User到Role的多对多:
从 User 出发,我们也可以发现一个用户可以具有多个角色,这样用户到角色的关系也还是一对多关系。这样
我们就可以认为 User 与 Role 的多对多关系,可以被拆解成两个一对多关系来实现。其情况也是雷同与从Role到User的多对多。