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 全局参数中配置开启二级缓存

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值