博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MyBatis 笔记
阅读量:6254 次
发布时间:2019-06-22

本文共 2902 字,大约阅读时间需要 9 分钟。

Mybatis

基础用法

  1. 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.Driverdb.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf8db.username=your namedb.password=your pass
  1. 建立pojo文件User.java,注意内置引用.
public class User {       private int id;        private String userName;        private String userAge;        private String userAddress;        //省略get set        }
  1. 建立mybatis和Spring的配置文件applicationContext.xml,批量配置
  1. 新建mapper包,建立mapper文件UserMapper.xml

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.明确业务表中 表与表的关系(比如用户和订单)

  • 一对一
  • 一对多
  • 多对多

延时加载

img_d25364ee46a254f0db34424e4d4e4789.png
image.png

Mybatis的缓存,包括一级缓存和二级缓存

一级缓存指的就是sqlsession,在sqlsession中有一个数据区域,是map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。

二级缓存指的就是同一个namespace下的mapper,二级缓存中,也有一个map结构,这个区域就是一级缓存区域。一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。

一级缓存是默认使用的。

二级缓存需要手动开启。

原理

一级缓存

img_65a6e6885490afebf763d999c9bdb419.png
image.png

二级缓存

img_1d05806c03f3984ab4f0b9c3a304c954.png
image.png

开启二级缓存

  1. 开启二级缓存的总开关

    img_c75f6d9f7f43d658215154b4a9ec6349.png
    image.png
  2. 在mapper映射文件中开启二级缓存

其他缓存策略

Mybatis本身是一个持久层框架,它不是专门的缓存框架,所以它对缓存的实现不够好,不能支持分布式。

系统为了提高性能,通常会对系统采用分布式部署(集群部署方式)

img_2722318af5d66ab6a13eb640af115d7a.png
image.png

Cache是一个接口,它的默认实现是mybatis的PerpetualCache。如果想整合mybatis的二级缓存,那么实现Cache接口即可。

对于访问响应速度要求高,但是实时性不高的查询,可以采用二级缓存技术。

注意:在使用二级缓存的时候,要设置一下刷新间隔(cache标签中有一个flashInterval属性)来定时刷新二级缓存,这个刷新间隔根据具体需求来设置,比如设置30分钟、60分钟等,单位为毫秒。

Mybatis二级缓存对细粒度的数据,缓存实现不好。

场景:对商品信息进行缓存,由于商品信息查询访问量大,但是要求用户每次查询都是最新的商品信息,此时如果使用二级缓存,就无法实现当一个商品发生变化只刷新该商品的缓存信息而不刷新其他商品缓存信息,因为二级缓存是mapper级别的,当一个商品的信息发送更新,所有的商品信息缓存数据都会清空。
解决此类问题,需要在业务层根据需要对数据有针对性的缓存。
比如可以对经常变化的 数据操作单独放到另一个namespace的mapper中。

转载地址:http://zrxsa.baihongyu.com/

你可能感兴趣的文章
执行计划基础 动态采样
查看>>
第八周总结
查看>>
不断进步
查看>>
关于PowerDesigner出现不允许有扩展属性,或对象不存在的解决办法
查看>>
JS-鼠标彩色拖尾小效果
查看>>
Linux 文件权限
查看>>
Jsoup解析HTML
查看>>
作为一个程序员为什么要写博客?
查看>>
【HZOI2015】帕秋莉的超级多项式
查看>>
验证码
查看>>
其他综合-Kickstart无人值守安装系统CentOS 7
查看>>
oracle Wallet的使用
查看>>
Scala-基础-运算符
查看>>
直接在存储过程里面写sql语句的话 ,会返回操作的结果
查看>>
2019-4-25 html学习笔记
查看>>
团队作业
查看>>
DL一(ML基础知识)
查看>>
Python3使用tkinter编写GUI程序
查看>>
在vue项目中使用monaco-editor
查看>>
计蒜客 蓝桥杯模拟二 区间合并 打扫教室
查看>>