转自:http://blog.csdn.net/xulu_258/article/details/46623317

所谓多条件查询即为用户输入想要查询的条件,然后根据用户输入的条件进行查询。

当用户有可能什么也不输入,这个条件我们应该考虑到。如果不输入就查询,则我们在页面上显示所有的查询结果,

当用户输入一个条件,我们则根据用户输入的这一个条件来进行查询,两个条件,三个条件也是一样,

而这个时候我们就应该考虑一下查询条件是可变的,我们应该怎样根据可变的条件来书写sql语句,我们应该首先会想到if条件语句,如果用户输入,我们就把输入的添加到sql语句中,但是这样的话我们应该考虑到实际情况下,如果突然客户又让我们加一个条件,我们又得重新更改我们的if条件语句,不仅复杂而且浪费时间;

因此我们得重新考虑一种解决方法,可以用StringBuilder来new一个基本的查询语句,例如:"select * from customer(表名) where 1=1",

where 1=1 :就是为了append后面的and语句的,and语句需要在where后面嘛,之后的条件是通过 if 块动态变化的,比如下面这一段代码

要查询的字段有:cname gender cellphone email

首先定义sql的前半段固定代码

"select * from t_customer where 1=1"
当cname选项被选中时,
sql.append(" and cname like ?"); 
sql查询语句就变成了:
select * from t_customer where 1=1 and cname like ?
当gender也被选中时,sql查询语句就变成了:
select * from t_customer where 1=1 and cname like ? and gender=?

以此类推
public List<Customer> query(Customer criteria) {
try{
//给出sql模板,为了便于后面添加sql语句
StringBuilder sql =new StringBuilder("select * from t_customer where 1=1");
//给出parmas
List<Object> parmas = new ArrayList<Object>(); String cname = criteria.getCname();
if(cname != null && !cname.trim().isEmpty()){
sql.append(" and cname like ?");
parmas.add("%" +cname+ "%");
} String gender= criteria.getGender();
if(gender != null && !gender.trim().isEmpty()){
sql.append(" and gender=?");
parmas.add(gender);
} String cellphone= criteria.getCellphone();
if(cellphone != null && !cellphone.trim().isEmpty()){
sql.append(" and cellphone like ?");
parmas.add("%" +cellphone+ "%");
} String email= criteria.getEmail();
if(email != null && !email.trim().isEmpty()){
sql.append(" and email like ?");
parmas.add("%" +email+ "%");
} return qr.query(sql.toString(), new BeanListHandler<Customer>(Customer.class),parmas.toArray()); }catch(SQLException e){
throw new RuntimeException(e);
} }

解决了这个问题,我们就知道了有多少个问号,我们就向集合中添加这个属性,最后执行QueryRunner的query方法即可。

java web中的多条件查询的更多相关文章

  1. JDBC在Java Web中的应用——分页查询

    分页查询 通过JDBC实现分页查询的方法有很多种,而且不同的数据库机制也提供了不同的分页方式,在这里介绍两种非常典型的分页方法. 通过ResultSet的光标实现分页 通过ResultSet的光标实现 ...

  2. Java web中常见编码乱码问题(一)

    最近在看Java web中中文编码问题,特此记录下. 本文将会介绍常见编码方式和Java web中遇到中文乱码问题的常见解决方法: 一.常见编码方式: 1.ASCII 码 众所周知,这是最简单的编码. ...

  3. 深入分析Java Web中的编码问题

    编码问题一直困扰着我,每次遇到乱码或者编码问题,网上一查,问题解决了,但是实际的原理并没有搞懂,每次遇到,都是什么头疼. 决定彻彻底底的一次性解决编码问题. 1.为什么要编码 计算机的基本单元是字节, ...

  4. Java Web 中使用ffmpeg实现视频转码、视频截图

    Java Web 中使用ffmpeg实现视频转码.视频截图 转载自:[ http://www.cnblogs.com/dennisit/archive/2013/02/16/2913287.html  ...

  5. JDBC在Java Web中的应用

    JDBC在Java Web中的应用 制作人:全心全意 在Java Web开发中,JDBC的应用十分广泛.通常情况下,Web程序操作数据库都是通过JDBC实现,即使目前数据库方面的开源框架层出不穷,但其 ...

  6. Redis(十四)Redis 在Java Web 中的应用

    在传统的 Java Web 项目中,使用数据库进行存储数据,但是有一些致命的弊端,这些弊端主要来自于性能方面. 由于数据库持久化数据主要是面向磁盘,而磁盘的读/写比较慢,在一般管理系统中,由于不存在高 ...

  7. Java Web 中 过滤器与拦截器的区别

    过滤器,是在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts的 action进行业务逻辑,比如过滤掉非法u ...

  8. JAVA WEB 中的编码分析

    JAVA WEB 中的编码分析 */--> pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-co ...

  9. Java web中常见编码乱码问题(二)

    根据上篇记录Java web中常见编码乱码问题(一), 接着记录乱码案例: 案例分析:   2.输出流写入内容或者输入流读取内容时乱码(内容中有中文) 原因分析: a. 如果是按字节写入或读取时乱码, ...

随机推荐

  1. linux下安装与运行docker

    写者环境: 1.lsb_release -a hello@hello:~$ lsb_release -aNo LSB modules are available.Distributor ID: Ubu ...

  2. json字符窜转对象

    第一种方法: 注意引用:using System.Runtime.Serialization.Json; using System.IO; static void Main(string[] args ...

  3. CenterOS下从零起步简单部署RockMongo

    使用Mongodb,对于调试Query,查看Collection等状态,有Rockmongo是非常方便的. 研究了下Rockmongo的部署,主要是依赖PHP环境的web服务器,当前有两种服务器,一种 ...

  4. Source not found :Edit Source Lookup Path 解决方案

    作者原创,转载请注明转载地址 在eclipse中用debug调试的时候,出现了以下问题,很是尴尬,经常碰到,所以有必要进行总结一下: 对该问题有两种解决方案, 一种比较文明:解决方法可参考如下网址: ...

  5. 02_Python简单爬虫(熊猫直播LOL的up主,谁最强!)

    声明: 本文仅用于Python练手,并无任何恶意攻击行为! # 导入request模块 from urllib import request # 导入re模块 import re class Spid ...

  6. yunw

  7. perl usage()和getopt

    #!/usr/bin/perl#perl search.pl --infile Targets.Lung.Carcinoma.genelist.txt --homogene Homo_sapiens. ...

  8. Java中的RTTI

    RTTI可以帮助我们在运行时识别对象和类的信息. 一般传统的RTTI有三种实现方式: 1. 向上转型或向下转型(upcasting and downcasting),在java中,向下转型(父类转成子 ...

  9. 小米笔记本 air 12.5寸 支持硬盘参数

    M.2接口 2280规格 单面芯片固态硬盘 PCIE协议

  10. mysql处理时间戳

    select name,telphone,FROM_UNIXTIME(add_time,'%Y-%m-%d %H:%i') as add_time from tf_apply_join order b ...