Mybatis
基础用法
- sql数据,建表,注意主外键 关系, 以及建立
db.properties
CREATE TABLE user(
id int AUTO_INCREMENT,
userName VARCHAR(255) not NULL,
userAge VARCHAR(255) not NULL,
userAddress VARCHAR(255) not NULL,
PRIMARY KEY (id)
)ENGINE =INNODB DEFAULT CHARSET=utf8;
db.driver=com.mysql.jdbc.Driver
db.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf8
db.username=your name
db.password=your pass
- 建立pojo文件
User.java
,注意内置引用.
public class User {
private int id;
private String userName;
private String userAge;
private String userAddress;
//省略get set
}
- 建立mybatis和Spring的配置文件
applicationContext.xml
,批量配置
<!-- 加载java的配置文件 -->
<context:property-placeholder location="db.properties" />
<!-- 创建数据源 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${db.driver}" />
<property name="url" value="${db.url}" />
<property name="username" value="${db.username}" />
<property name="password" value="${db.password}" />
<property name="maxActive" value="10" />
<property name="maxIdle" value="5" />
</bean>
<!-- SqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 指定mybatis的全局配置文件的路径 -->
<property name="configLocation" value="mybatis/SqlMapConfig.xml"></property>
<!-- 数据源 -->
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 1 可以 配置UserMapper代理类 -->
<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<!-- 设置代理类的接口 -->
<property name="mapperInterface" value="com.ccj.ms.mapper.UserMapper"></property>
<!-- 依赖注入SqlSessionFactory -->
<property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
</bean>
<!-- 2 或者 批量配置mapper代理类,默认bean的id为类名首字母小写 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 配置扫描的包 -->
<property name="basePackage" value="com.ccj.ms.mapper"></property>
<!-- 默认不需要配置SqlSessionFactory(只有一个SqlSessionFactory时),单独配置也可以 -->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
- 新建mapper包,建立mapper文件
UserMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="user">
<!-- 根据用户ID查询用户信息 -->
<select id="findUserById" parameterType="int" resultType="user">
SELECT
* FROM USER WHERE id =#{id}
</select>
</mapper>
5.用spring包下的UserDaoImpl
访问
public class UserDaoImpl extends SqlSessionDaoSupport implements UserDao {
@Override
public User findUserById(int id) throws Exception {
return this.getSqlSession().selectOne("user.findUserById", id);
}
}
6.测试
public class UserDaoTest {
private ApplicationContext ctx;
@Before
public void setUp() throws Exception {
ctx = new ClassPathXmlApplicationContext(
"spring/applicationContext.xml");
}
@Test
public void testFindUserById() throws Exception {
// 创建UserDao
UserDao dao = (UserDao) ctx.getBean("userDao");
User user = dao.findUserById(1);
System.out.println(user);
}
}
进阶用法
1.高级结果映射
前提
1.明确每张表的储存信息
2.明确每张表的关键字段(主键,外键,非空)
3.明确数据库中表与表之间的外键关系(比如订单列别 和 订单详情)
4.明确业务表中 表与表的关系(比如用户和订单)
- 一对一
- 一对多
- 多对多
延时加载
Mybatis的缓存,包括一级缓存和二级缓存
一级缓存指的就是sqlsession,在sqlsession中有一个数据区域,是map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。
二级缓存指的就是同一个namespace下的mapper,二级缓存中,也有一个map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。
一级缓存是默认使用的。
二级缓存需要手动开启。
原理
一级缓存
二级缓存
开启二级缓存
-
开启二级缓存的总开关
- 在mapper映射文件中开启二级缓存
其他缓存策略
Mybatis本身是一个持久层框架,它不是专门的缓存框架,所以它对缓存的实现不够好,不能支持分布式。
系统为了提高性能,通常会对系统采用分布式部署(集群部署方式)
Cache是一个接口,它的默认实现是mybatis的PerpetualCache。如果想整合mybatis的二级缓存,那么实现Cache接口即可。
对于访问响应速度要求高,但是实时性不高的查询,可以采用二级缓存技术。
注意:在使用二级缓存的时候,要设置一下刷新间隔(cache标签中有一个flashInterval属性)来定时刷新二级缓存,这个刷新间隔根据具体需求来设置,比如设置30分钟、60分钟等,单位为毫秒。
Mybatis二级缓存对细粒度的数据,缓存实现不好。
场景:对商品信息进行缓存,由于商品信息查询访问量大,但是要求用户每次查询都是最新的商品信息,此时如果使用二级缓存,就无法实现当一个商品发生变化只刷新该商品的缓存信息而不刷新其他商品缓存信息,因为二级缓存是mapper级别的,当一个商品的信息发送更新,所有的商品信息缓存数据都会清空。
解决此类问题,需要在业务层根据需要对数据有针对性的缓存。
比如可以对经常变化的 数据操作单独放到另一个namespace的mapper中。