在将 varchar 值 '' 转换成数据类型 int 时失败

论坛 期权论坛 脚本     
匿名技术用户   2020-12-28 10:45   37   0

我们有时候用in语句的时候,发现存在Sql注入漏洞,想参数化处理一下,遇到语句执行问题!!

declare @ids varchar(256)
set @ids='216,218'
select * from tbl_temp where id in(@ids)

  但是还是必须要解决Sql注入的问题,解决方案:利用CHARINDEX系统函数处理

declare @ids varchar(256)
set @ids='216,218'
select * from tbl_temp where CHARINDEX(','+LTRIM(id)+',',','+@ids+',')>0

查到正确的数据结果。

转载于:https://www.cnblogs.com/mingjia/p/6088543.html

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP