Mybatis中标签的深入以及连接池和事物控制
1.mybatis中连接池使用及分析
1.连接池:
在实际开发过程中都会使用连接池
因为他可以减少我们获取链接所消耗的时间
2.mybatis中的连接池
mybatis连接池提供了3种方式的配置:
配置的位置:
主配置文件SqlMapConfig.xml中的dataSource标签,type属性表示采用何种连接池方式。
type属性的取值:POOLED 采用传统的javax.sql.DataSource规范中的连接池,mybatis中有针对规范的实现
UNPOOLED 采用传统的获取链接的方式,虽然也实现了javax.sql.DataSource接口,但是并没有使用池的思想。
JNDI 采用服务器提供的JNDI技术实现,来获取DataSource对象,不同的服务器所能拿到的对象是不一样的。
注意:如果不是web或者maven的war工程,是不能使用的。
我们使用的是tomcat服务器,采用的连接池是dbcp连接池。
mybatis事物控制的分析
3.mybatis中的事物?
什么是事物
事物的四大特性ACID
不考虑隔离性会产生的3个问题
解决办法:四种隔离级别
它是通过sqlsession对象的commit方法和rollback方法实现事物的提交和回滚
2.mybatis基于xml配置的动态sql语句使用
mapper配置文件中的几个标签:<if>、<where>、<foreach>、<sql>。
实体类:user:
@Data
public class User {
private Integer id;
private String username;
private Date birthday;
private String sex;
private String address;
QueryVo:
@Data
public class QueryVo {
private User user;
private List<Integer> ids;
Dao接口:
/**
* 用户持久层接口
*/
public interface IUserDao {
/**
* 根据传入的参数条件查询
* @param user 查询的条件,又可能有用户名,有可能有性别,也有可能有地址
* @return
*/
List<User> findUserByCondition(User user);
/**
* 根据queryvo提供的id集合,查询用户信息。
* @param vo
* @return
*/
List<User> findUserInIds(QueryVo vo);
}
<if>标签的使用:
<!--根据条件查询-->
<select id="findUserByCondition" resultType="com.dyz.domain.User" parameterType="user">
select * from user where 1=1
<if test="username != null">
and username = #{username}
</if>
<if test="sex != null">
and sex = #{sex}
</if>
</select>
<where>标签的使用:
<select id="findUserByCondition" resultType="com.dyz.domain.User" parameterType="user">
select * from user
<where>
<if test="username != null">
and username = #{username}
</if>
<if test="sex != null">
and sex = #{sex}
</if>
</where>
</select>
test测试方法:
/**
* 测试查询所有
*/
@Test
public void testFindByCondition(){
User user = new User();
user.setUsername("耶稣");
// user.setSex("女");
List<User> users = userDao.findUserByCondition(user);
for (User user1:users){
System.out.println(user1);
}
}
<foreach>标签的使用:
<!--根据queryvo中的id集合查询用户列表-->
<select id="findUserInIds" resultType="com.dyz.domain.User" parameterType="queryvo">
select * from user
<where>
<if test="ids != null and ids.size()>0">
<foreach collection="ids" open="and id in (" close=")" item="uid" separator=",">
#{uid}
</foreach>
</if>
</where>
</select>
SQL语句:select 字段 from user where id in ( ? , ? )
标签用于遍历集合,它的属性:
collection:代表要遍历的集合元素,注意编写时不要写#{}
open:代表语句的开始部分
close:代表结束部分
item:代表遍历集合的每个元素,生成的变量名
separator:代表分隔符
test测试方法:
/**
* 测试foreach标签的使用
*/
@Test
public void testFindInIds(){
QueryVo vo = new QueryVo();
List<Integer> list=new ArrayList<Integer>();
list.add(1);
list.add(12);
list.add(13);
vo.setIds(list);
List<User> users = userDao.findUserInIds(vo);
for (User user1:users){
System.out.println(user1);
}
}
<sql>标签的使用
<!--抽取重复的sql语句-->
<sql id="defaultUser">
select * from user
</sql>
<!--配置查询所有-->
<select id="findAll" resultType="com.dyz.domain.User">
<include refid="defaultUser"></include>
<!--select * from user-->
</select>
用于抽取映射文件中重复多次的sql语句。