mybatis中的#和$的区别

1.#将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:where id=#{id}
如果id传入的值是111,那么解析成SQL的值为where id=”111”;如果传入的值是id,则解析成的sql为where id = “id”。
2. SQLwhereid= {userid},如果传入的值是111,那么解析成SQL时的值为where id=userid,如果传入的值是id,则解析成的SQL为where id=id。
3.#方式能够很大程度防止SQL注入。
4.$方式无法防止SQL注入。

5.$方式一般用于数据库对象,例如传入表名。
如果tableName为user_role,则

select * from ${tableName} where user_code = #{userCode}

是正确的。
6.一般能用#的就别用$.

7.myBatis排序时使用order by 动态参数时需要注意,用$而不是#

举个例子大家就会明白的。写一句SQL-例如:

select * from user_role where user_code = "100";

这句话而言,需要写成

select * from ${tableName} where user_code = #{userCode}

所以,$符是直接拼成sql的 ,#符则会以字符串的形式 与sql进行拼接。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值