• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

sql多条件查询

php 搞代码 4年前 (2022-01-23) 26次浏览 已收录 0个评论
文章目录[隐藏]

要实现多条件查询 其中值为0时为不限条件 怎么用sql实现

例如:查询某地区某类型商铺 有可能地区为不限 类型本文来源gao@!dai!ma.com搞$$代^@码!网!搞gaodaima代码为中餐 查询时就不需要where 地区=值,而是只有where 类型=中餐,选择地区为北京 类型为中餐 查询时就是where 地区=北京 AND 类型=中餐。

然后还有很多其他条件,在后端用if else判断之后再用不同的sql语句查询的话太繁琐了,不太了解sql但我觉得sql应该有相应的解决方案,求教。

回复内容:

要实现多条件查询 其中值为0时为不限条件 怎么用sql实现

例如:查询某地区某类型商铺 有可能地区为不限 类型为中餐 查询时就不需要where 地区=值,而是只有where 类型=中餐,选择地区为北京 类型为中餐 查询时就是where 地区=北京 AND 类型=中餐。

然后还有很多其他条件,在后端用if else判断之后再用不同的sql语句查询的话太繁琐了,不太了解sql但我觉得sql应该有相应的解决方案,求教。

你可以if判断了以后在拼入相应的where
ex: $sql = select * from xxx where 1=1;

<code>if(类型!=0){    $sql .= 'and where 类型 = 中餐';}</code>

把查询的条件作为一个Map params; 然后用一个方法进行额外查询语句的拼接;

<code>public String getWhere(Map params) {    String str = "";        if(params.size() > 0) {        boolean and = false;        for(String param : params.keySet()) {            Object value = params.get(param);            if(value == null || value.equals(0)) {                continue;            } else {                if(and) {                    str = str + " and " + param + " = " + " " + value;                } else {                    and = true;                    str = str + param + " = " + " " + value;                }                            }        }    }        if(str != "") {         str = " where " + str;    }        return str;}</code>

mybatis拼SQL
JPA拼creteria

链接条件 and or

查询Mysql是使用字符串来传递Mysql查询命令的,所以要修改where后面的查询条件是完全可行的,可以先建立一个存储这些命令的字符串数组,在用户每次修改条件,例如勾选了地址,就修改数组的相应值,或者在点击查询后,检查界面中那些组件,例如餐类或者地址被勾选了,就获取他们的值,添加到数组中,然后在开始查询是遍历他们,为空的就不做处理,不为空的就添加到统一条件字符串里,最后添加到查询语命令字符串中就可以啦
string cmd = “select * from 表名 where 统一条件”
新手一只,考虑可能不周,不过这中做法应该没什么大问题哈


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:sql多条件查询

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址