sql语句预处理,模糊查询时占位符不替换成参数

sql语句预处理时,正常情况下:select*frombookwherebname=?;其中的占位符?会自动替换为传递的参数但是:select*frombookwhere... sql语句预处理时,正常情况下:select * from book where bname = ?; 其中的占位符?会自动替换为传递的参数
但是:select * from book where bname like '%?%' 其中占位符却成了sql语句的一部分,不会替换成参数

我是在用php的pdo操作mysql时遇到的问题,以前java用jdbc操作sqlserver时好像也遇到过,但忘记怎么处理的了
有经验的前辈解答下吗?谢谢
展开
 我来答
gongjiaxiang50
2017-08-12 · TA获得超过3171个赞
知道大有可为答主
回答量:2432
采纳率:50%
帮助的人:1097万
展开全部
还是用 select * from book where bname like ?
然后参数赋予值时,再用通配符.
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式