myBatis 日记
一级缓存默认开启, 有效范围是在当前sqlsession,
同一个SqlSession对象执行相同的sql并参数也要相同,缓存才有效。
在同一个会话里面,多次执行相同的SQL 语句,会直接从内存取到缓存的结果
一级缓存不足: 使用一级缓存的时候,因为缓存不能跨会话共享,不同的会话之间对于相同的数据可能有不一样的缓存。在有多个会话或者分布式环境下,会存在脏数据的问题。
二级缓存的有效方范围是 Mapper(NameSpace), 多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。二级缓存的作用范围更大。
注入的单例 SqlSessionTemplate 内部包含SqlSessionProxy对象, 对每次SqlsessionTemplate的调用被代理为新创建的sqlsession的调用,所以sqlsessiontemplate每次调用都会有一个新的session生成.
SqlSession 持有了一个Executor 对象,用来封装对数据库的操作。
SqlSession 持有了一个Configuration对象,用来保存所有配置信息。
二级缓存范围更广,工作在SqlSession外部(如果启动二级缓存, myBatis在创建Executor时会自动对Executor进行装饰, 装饰器就是CacheingExecutor),而一级缓存存在于sqlsession内层, 所以一级缓存存在于二级缓存之前, 

Mybatis基本框架

SimpleExecutor, ReuseExecutor, BatchExecutor 区别
SimpleExecutor:每执行一次update 或select,就开启一个Statement 对象,用完立刻关闭Statement 对象。
ReuseExecutor:执行update 或select,以sql 作为key 查找Statement 对象,存在就使用,不存在就创建,用完后,不关闭Statement 对象,而是放置于Map 内,供下一次使用。简言之,就是重复使用Statement 对象。
BatchExecutor:执行update(没有select,JDBC 批处理不支持select),将所有sql 都添加到批处理中(addBatch()),等待统一执行(executeBatch()),它缓存了多个Statement 对象,每个Statement 对象都是addBatch()完毕后,等待逐一执行executeBatch()批处理。与JDBC 批处理相同。
获得Mapper 对象的过程,实质上是获取了一个MapperProxy 的代理对象。
MapperProxy 中有sqlSession、mapperInterface、methodCache。
MapperProxy执行过程
org.apache.ibatis.binding.MapperProxy#invoke
org.apache.ibatis.binding.MapperMethod#execute
org.apache.ibatis.binding.MapperMethod#executeForMany
org.apache.ibatis.session.SqlSession#selectList
MapperMethod 里面主要有两个属性, 一个是SqlCommand , 一个是MethodSignature,这两个都是MapperMethod 的内部类。
根据不同的type 和返回类型:调用convertArgsToSqlCommandParam()将参数转换为SQL 的参数。调用sqlSession 的insert()、update()、delete()、selectOne ()方法,我们以查询为例,会走到selectOne()方法。
MyBatis设计模式

MyBaits 支持哪些数据源类型
UNPOOLED:不带连接池的数据源。
POOLED : 带连接池的数据源, 在PooledDataSource 中维护PooledConnection。
JNDI:使用容器的数据源,比如Tomcat 配置了C3P0。
自定义数据源:实现DataSourceFactory 接口,返回一个DataSource。
当MyBatis 集成到Spring 中的时候,使用Spring 的数据源。
PooledDataSource 的getConnection()方法流程图:

MyBatis 翻页的几种方式和区别?
逻辑翻页:通过RowBounds 对象。
物理翻页:通过改写SQL 语句,可用插件拦截Executor 实现
MyBatis 集成到Spring 的原理是什么?
SqlSessionTemplate 中有内部类SqlSessionInterceptor 对DefaultSqlSession进行代理;
MapperFactoryBean 继承了SqlSessionDaoSupport 获取
SqlSessionTemplate;接口注册到IOC 容器中的beanClass 是MapperFactoryBean。
为什么SqlSessionTemplate 是线程安全的?
其内部类SqlSessionInterceptor 的invoke()方法中的getSqlSession()方法:
如果当前线程已经有存在的SqlSession 对象,会在ThreadLocal 的容器中拿到SqlSessionHolder,获取DefaultSqlSession。
如果没有,则会new 一个SqlSession,并且绑定到SqlSessionHolder,放到ThreadLocal 中。
SqlSessionTemplate 中在同一个事务中使用同一个SqlSession。
调用closeSqlSession()关闭会话时,如果存在事务,减少holder 的引用计数。否则直接关闭SqlSession。
#和$的区别:
1、是否能防止SQL 注入:$方式不会对符号转义,不能防止SQL 注入
2、性能:$方式没有预编译,不会缓存
1、能用#的地方都用#
2、常量的替换,比如排序条件中的字段名称,不用加单引号,可以使用$
myBatis 日记的更多相关文章
- MyBatis日记(五):一对一关系,一对多关系
一对一关系: 首先在数据库中新增地址表(t_address)用于存储人员的地址信息: CREATE TABLE `t_address` ( `id` ) NOT NULL AUTO_INCREMENT ...
- MyBatis日记(四):MyBatis——insert、update、delete、select
MyBatis简单增删改查操作,此处所做操作,皆是在之前创建的MyBatis的Hello world的工程基础上所做操作. 首先在接口文件(personMapper.java)中,添加操作方法: pa ...
- Mybatis日记
SqlSession build: ExecutorType :SIMPLE ,REUSE, BATCH, SIMPLE 为默认执行器: REUSE 为可重用执行器,重用Statement,执行器会缓 ...
- mybatis日记配置Log4j
拷贝log4j-1.2.16.jar到项目lib下 方式一是在src下新建一个log4j.xml文件,其具体内容如下 <?xml version="1.0" encoding ...
- MYbatis调试日记(三)
如何在Mybatis中插入日期类型的数据 直接见代码: xml配置文件 java代码
- mybatis学习日记-day01
Mybatis说明: MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的 ...
- MyBatis学习日记(三):戏说MyBatis配置文件
properties标签 properties标签可以用来加载别的配置文件,比如可以加载数据库的配置文件,jdbc.properties. 下面是jdbc.properties jdbc.driver ...
- MyBatis学习日记(二): MyBatis Say Hello
首先在Eclipse中创建一个maven工程: 在maven工程下的pom.xml文件中添加MyBatis.MySQL.Junit依赖: <project xmlns="http:// ...
- MyBatis学习日记(一):拜见小主——MyBatis
近日学习MyBatis,特将学习过程及一点心得记录于此. MyBatis为何物? MyBatis 是支持定制化SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC ...
随机推荐
- QString 字符串操作
Qt QString字符串分割.截取(转载) 在做项目中不可避免的会使用到一串字符串中的一段字符,因此常常需要截取字符串. 有两种方式可以解决这个问题: 方法一:QString分割字符串: QStri ...
- 【Gin-API系列】Gin中间件之鉴权访问(五)
在完成中间件的介绍和日志中间件的代码后,我们的程序已经基本能正常跑通了,但如果要上生产,还少了一些必要的功能,例如鉴权.异常捕捉等.本章我们介绍如何编写鉴权中间件. 鉴权访问,说白了就是给用户的请求增 ...
- Android开发之 当前日期String类型转date类型 java代码中实现方法
/** * 获取当前时间 * * @return */ public Date getDate(String str) { try { java.text.SimpleDateFormat forma ...
- Unity报与System.IO相关的错误
比如这个: Type `System.IO.FileInfo' does not contain a definition for `OpenText' and no extension method ...
- Substance Painter教程
https://huke88.com/route/substance-painter.html?sem=baidu&kw=106738
- [BUUOJ记录] [BJDCTF2020]EasySearch
前面的突破点考察swp泄露以及md5截断认证,最后一步考察ssi注入 进入题目是一个登陆页面什么提示都没有,工具扫了一下发现swp泄露,得到登录验证页面的源码: <?php ob_start() ...
- google protocol buffer——protobuf的问题及改进一
这一系列文章主要是对protocol buffer这种编码格式的使用方式.特点.使用技巧进行说明,并在原生protobuf的基础上进行扩展和优化,使得它能更好地为我们服务. 在上一篇文章中,我们完整了 ...
- Mysql慢查询(配置)
慢查询?什么鬼?查询很慢吗?刚看一脸萌,学无止境 好吧,就是执行很慢的SQL 什么是慢查询 慢查询定义及作用 慢查询日志,顾名思义,就是查询慢的日志(感觉在说F话),是指Mysql记录所有执行超过lo ...
- java之5分钟插入千万条数据
虽说不一定5分钟就插入完毕,因为取决去所插入的字段,如果字段过多会稍微慢点,但不至于太慢.10分钟内基本能看到结果. 之前我尝试用多线程来实现数据插入(百万条数据),半个多小时才二十多万条数据. 线程 ...
- git多账号使用
1 背 景 在公司上班的员工会同时拥有两个git账号, 一个是公司内部的, 仅允许工作时使用; 另一个是个人的, 常用于日常的学习记录. 此时, 面临的问题是如何在一台电脑(客户端)上正常使用两个账号 ...