mybaits

一、mybaits $ 和 # 的区别

(1)使用${}方式传入的参数,mybatis不会对它进行特殊处理

        例:使用以下SQL

select id,name,age from student where id =${id}

        当我们传递的参数id为 "1" 时,上述 sql 的解析为

select id,name,age from student where id =1

(2)使用#{}传进来的参数,mybatis默认会将其当成字符串

        例:使用以下SQL

select id,name,age from student where id =#{id}

        当我们传递的参数id为 "1" 时,上述 sql 的解析为

select id,name,age from student where id ="1"

        能使用#{}的地方应尽量使用#{},#{}可以有效防止sql注入

二、mybaits 一级缓存和二级缓存

        一级缓存被称为SqlSession级别的缓存,二级缓存被称为表级缓存

        一级缓存的作用域默认是一个SqlSession。Mybatis默认开启一级缓存。也就是第一次执行 select 完毕会将查到的数据写入 SqlSession 内的 HashMap 中缓存起来;第二次以后是直接去缓存中取。所以重复执行查询操作的时候,第二次明显要比第一次快。

        如果 SqlSession 执行了 DML 操作(insert、update、delete),并 commit 了,那么 mybatis 就会清空当前 SqlSession 缓存中的所有缓存数据,这样可以保证缓存中的存的数据永远和数据库中一致,避免出现差异

        二级缓存是 mapper级别的缓存,也就是同一个namespace的mapper.xml ,当多个 SqlSession 使用同一个 Mapper 操作数据库的时候,得到的数据会缓存在同一个二级缓存区域。二级缓存默认是没有开启的。需要在 setting 全局参数中配置开启二级缓存

你可能感兴趣的:(mybaits,框架,java)