mybatis中一些需要注意的地方和平时不太会注意的小细节

在使用 select * from user where username like '%小白%'  ;  这种语句时,使用${}和#{}会出现不同的sql语句

#{}:   select * from user where username like '%#{username}%' 

           select * from user where username like '%'小白'%' 

${}:   select * from user where username like '%${username}%' 

           select * from user where username like '%小白%' 

${}:相当与以前常用的 Statement,起到‘+’的作用。但是当parametertype是String,Date和基本类型的时候,参数名必须是value

${value},并且,因为是起到‘+’的作用,所以会有sql注入的风险。

#{}:相当于以前的PreparedStatement ,起到占位符的作用,当parametertype是String,Date和基本类型的时候,参数名随便起,不按名称匹配。

 

mybaties 缓存机制,mybatis一级缓存方法级,二级缓存namespace级别,这个mapper中,对一些历史表进行查询,不进行增删改,这样就可以通过mybatis的二级缓存有效提高效率了,但是mybatis二级缓存需要手动在<setting>中开启

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值