为什么Mybatis中sql返回的结果和数据库中sql返回的结果不一样。如果sql有in,那么注意#{}和${}的用法

在Mybatis中,遇到一个情况,比如sql语句是:

select * from user where age in (#{age})

age在Dao层传过来是String类型,比如是age="7,23"。

首先要明白,数据库中,age字段是int型,而Dao层,传过来是String型。

如果用#{}的方式赋值,表示#{}里面的参数会带上“”,例子:select * from user where age in ("7,23")

这样肯定是不对的。所以在这里,我们要用${}

如果用${}赋值,表示传过来的参数不会发生变化,传过来是什么样子,就是什么样子。

例子:select * from user where age in (7,23)

如果你遇到的也是这个问题,不妨看看你的赋值方式。

这里啰嗦两句。

#{}的赋值方式,主要是为了传参过程中带上“”,当数据库字段是char或者是varchar时,那就必须用这种。

${}的赋值方式,就跟#{}相反,主要是针对数据库字段是数值型,比如刚才,age就是数值型。值得注意的是,由于${}的这种方式是直接赋值,所以存在sql注入的风险。最好参数不让用户去操作,在程序中获取参数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值