如何实现SQL的多条件模糊查询

我现在的查询语句是:
sql="select * from TABLE where 问题1 like '"+答案1+"' and 问题2 like '"+答案2+"' and 问题3 like '"+答案3+"'……"
但是现在问题来了,有很多,那么
sql="select * from TABLE where 问题 like '"+答案+"' order by id"
请问这一句里的“问题”和“答案”都是上一个页面传递过来的多个值,请问该如何实现多条件模糊查询呢?
最新回答
迷失了就不酷了

2023-06-27 04:55:41

不知道我是否理解了你的意思。

由于不知道页面会传来多少个“问题”,你只能去手动拼接sql语句了。比如页面穿来了n个"问题“。
你只能去遍历,比如”问题"的name值为"answer",在前台你可以处理下,把所有的answer以逗号分割,比如"answer1,answer2..."

String answer[]=request.getParameter("anser").split(",")
String answerVal[]=request.getParameter("answerVal").split(",")

StringBuilder sb=new StringBuilder();
sb.append("select * from table where ")

for(int i=0,l=answer.length;i<l;i++){
sb.append(answer[i]+ " like '%"+answerVal[i]+"' and ");
}

sb.append(" 1=1 ")

String sql=sb.toString()

//execute query

这段代码不完整,会有点问题 但思路是这样的。还有 别直接这么写,建议用prepareStatement,否则会存在SQL注入。懂思想即可。
大大滴狡猾

2020-06-30 03:06:01

ere (1=1)"

if (exp1) then
str=str&" and ( 条件1)"
end if
if (exp2) then
str=str&" and ( 条件2)"
end if
if (exp3) then
str=str&" and ( 条件3)"
end if

str=str&" order by id desc"
鲜血染红嫁衣

2020-10-22 04:55:12

使用 or
问题 like '"+答案+"' or 问题 like '"+答案+"'
凉秋瑾言

2021-05-02 23:36:33

昨天不是问过了 没有简单方法的