java - 精确查询sql报错的问题
PHP中文网
PHP中文网 2017-04-18 09:51:36
[Java讨论组]

sql的where语句:"WHERE 1=1 AND DNAME IN (:dname) AND DNAME LIKE '%' || :mh_dname || '%'";
模糊查询中只传mh_dname的值的时候,这段sql可以正常执行,执行语句:
SQL statement [SELECT * FROM PRE_DOMAIN_ACC where ((1 = 1) AND (DNAME LIKE (('%' || ?) || '%'))) limit ?,?],因为dname没有传值,所以sql中自动省略DNAME In的语句,可以正常执行的是DNAME LIKE
但是在做精确查询的时候,只传递dname的值,sql就会报错,没有传递mh_dname的值,但是sql的DNAME LIKE仍然执行了,结果报错,因为不想把两条语句分开写,所以问下有没有好的办法解决
报错语句:SQL statement [select count(*) from PRE_DOMAIN_ACC where ((1 = 1) AND (DNAME IN (?)) AND (DNAME LIKE (|| '%')))]

PHP中文网
PHP中文网

认证0级讲师

全部回复(0)
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号