返回首页
当前位置: 主页 > 网络编程 > Php实例教程 >

利用逗号/空格 分割查询条件,实现多条件查询代码

时间:2010-10-31 15:21来源:知行网www.zhixing123.cn 编辑:麦田守望者

实现:input框内可以输入多个字符,用空格或逗号分割查询条件,逗号和空格可以混用,最后把查询的条件一并列出
例如输入:中国,美国, 法国 德国, ,日本 ,可以将符合各国的条件一并查出,忽略不符合规则的输入

需处理:
1.将多个空格格式化为一个空格
2.逗号分割既可用英文标点,又可以用中文标点
3.排除其他标点符号,如查询条件中有其他标点符号,则忽略掉
4.同时满足两个条件混查

主要代码
Pattern p = Pattern.compile("[' ']+").compile("[.。!?#@#¥$%&*()()=《》<>‘、’;:\"\\?!:']");
//正则,过滤多余空格和其他中英文标点
Matcher m = p.matcher(keyword);
String list1 = m.replaceAll(" ").replaceAll(",",",");
//replaceAll 将中文逗号替换为英文逗号
String list2 = StringUtils.replace(list1," ",",");
//将所有单个空格替换为英文逗号
String[] list = StringUtils.split(list2, ",");
//英文逗号为界,分割为数组

for (int j = 0; j < list.length; j++) {
System.out.println("list[j]=" + list[j]);
//处理后的查询字符串
}
完整查询代码,多个条件用or来查询:
if (StringUtils.isNotBlank(searchword)) {
String[] list = StringUtils.split(StringUtils.replace(Pattern.compile("[' ']+").compile("[.。!?#@#¥$%&*()()=《》<>‘、’;:\"\\?!:']").matcher(searchword).replaceAll(" ").replaceAll(",", ",")," ",","), ",");
if (list.length > 0) {
sql += " and ( ";
for (int j = 0; j < list.length; j++) {

if (j == 0) {
sql += " name like '%" + list[j] + "%'";
} else {
sql += " or name like '%" + list[j] + "%'";
}
}
sql += " )";
}
}

 

------分隔线----------------------------
标签(Tag):数据库 MYSQL MySQL教程 Mysql5
------分隔线----------------------------
推荐内容
猜你感兴趣