关于不定项参数的查询方法(多条件查询)

如果要进行一个多条件的查询,但又不知道用户到底对哪些条件进行了设定,所以,我们在编辑一个多条件查询的时候,会遇到这样的问题。

那么我们可以通过以下的方式进行解决:

假设一个场景-->       如下图:其中Customer.class 包含了以下的所有属性

         

开始解决问题:

那么我们在CustomerDao中可以这样进行编写:

public class CustomerDao{

  private QueryRunner qr = new TxQueryRunner(); //TxQueryRunner为自己的写的继承类 -->源代码在最下面

  public List<Customer> query(Customer c){

    StringBuffer sql = new StringBuffer("select * from t_customer where 1=1"); //重点。 此处解决掉了条件如何拼接的问题

    List<Object> list = new ArrayList<Object>();

    if(c.getCname!=null&&!c.getCname.trim().isEmpty()){

      sql.append(" and cname = ?");//and前面需要一个空格,与前面的内容分离开

      list.add(c.getCname);//把参数添加到 list 中

    }

    if(c.getGender!=null&&!c.getGender.trim().isEmpty()){

      sql.append(" and gender = ?");//and前面需要一个空格,与前面的内容分离开

      list.add(c.getGender);

    }

    if(c.getCellphone!=null&&!c.getCellphone.trim().isEmpty()){

      sql.append(" and cellphone = ?");//and前面需要一个空格,与前面的内容分离开

      list.add(c.getCellphone);

    }

    if(c.getEmail!=null&&!c.getEmail.trim().isEmpty()){

      sql.append(" and email = ?");//and前面需要一个空格,与前面的内容分离开

      list.add(c.getEmail);

    }

    return qr.update(sql.toString(),new BeanListHandler<Customer>(Customer.class),list.toArray());//返回结果

  }

}

-----结束-------

附:(需要依赖:dbutils.jar , mysql.jar,c3p0.jar+配置文件,mchange-commons.jar ,czk-tools-1.0.jar.)

1. t_customer-->指的是数据库中的表,它包含了cname、gender、cellphone、description

2. TxQueryRunner.class -->继承了QueryRunner.class的类。

  代码如下:

 1 public class TxQueryRunner extends QueryRunner{
 2
 3     @Override
 4     public int[] batch(String sql, Object[][] params) throws SQLException {
 5         Connection con = JdbcUtils.getConnection();
 6         int[] result = super.batch(con, sql, params);
 7         JdbcUtils.releaseConnection(con);
 8         return result;
 9     }
10
11     @Override
12     public <T> T query(String sql, ResultSetHandler<T> rsh, Object... params)
13             throws SQLException {
14         Connection con = JdbcUtils.getConnection();
15         T result = super.query(con, sql, rsh,params);
16         JdbcUtils.releaseConnection(con);
17         return result;
18     }
19
20     @Override
21     public <T> T query(String sql, ResultSetHandler<T> rsh) throws SQLException {
22         Connection con = JdbcUtils.getConnection();
23         T result = super.query(con, sql, rsh);
24         JdbcUtils.releaseConnection(con);
25         return result;
26     }
27
28     @Override
29     public int update(String sql, Object... params) throws SQLException {
30         Connection con = JdbcUtils.getConnection();
31         int result = super.update(con, sql, params);
32         JdbcUtils.releaseConnection(con);
33         return result;
34     }
35
36     @Override
37     public int update(String sql, Object param) throws SQLException {
38         Connection con = JdbcUtils.getConnection();
39         int result = super.update(con, sql, param);
40         JdbcUtils.releaseConnection(con);
41         return result;
42     }
43
44     @Override
45     public int update(String sql) throws SQLException {
46         Connection con = JdbcUtils.getConnection();
47         int result = super.update(con, sql);
48         JdbcUtils.releaseConnection(con);
49         return result;
50     }
51
52 }
时间: 2024-10-22 07:19:22

关于不定项参数的查询方法(多条件查询)的相关文章

通过带参数的Sql语句来实现模糊查询(多条件查询)

#region 通过带参数的Sql语句来实现模糊查询(多条件查询) StringBuilder sb = new StringBuilder("select * from books"); List<string> listWheres = new List<string>(); List<SqlParameter> listParams = new List<SqlParameter>(); if (txtBookName.Text.T

MyBatis模糊查询和多条件查询

MyBatis模糊查询和多条件查询 一.ISmbmsUserDao层 //根据姓名模糊查询 public List<Smbms> getUser(); //多条件查询 public List<Smbms> getLikeUser(@Param("userName") String userName , @Param("userCode") String userCode ); 二.小配置文件 ISmbmsUserDao.xml <!--

封装数据通用的查询方法(多行查询 单行查询 ) 以及调用时候需要注意的事项

/** * * @param sql 查询语句 * @param params 占位符对应的值 * @param handler 结果集一行的处理对象 * @return 处理后的对象的集合 * @throws SQLException */ //封装一个通用的多行查询方法 public static <T> List<T> query(String sql,Object [] params,ResultSetHandler<T> handler) throws SQL

调用DISCUZ 数据库查询方法进行数据库查询

<?php define('APPTYPEID', 5);//必须的,你懂的 define('CURSCRIPT', 'userapp');//必须的,你懂的 require_once './source/class/class_core.php';//必须的,你懂的 $discuz = & discuz_core::instance();//必须的,你懂的 $discuz->cachelist = $cachelist;//必须的,你懂的 $discuz->init();//必

orm 通用查询方法——GetOneModel 条件查询一个对象

数据连接层的方法封装成通用方法是很有必要,节省不必要的重复写代码. Golang的orm.xorm框架没有封装这些操作. 这里是一个查询单个对象的方法. 此处抛砖引玉,大家继续完善. 通用方法定义代码: /** * 描述:根据条件查询一个对象 * 作者:Tianqi * 日期:2014-09-04 * param model:*interface{} 对象实例 * param model:cond 查询条件 * return count:结果数 */ func GetOneModel(model

QBC查询、离线条件查询(DetachedCriteric)和分页查询模版

一.QBC检索步骤 QBC检索步骤: 1.调用Session的createCriteria()方法创建一个Criteria对象. 2.设定查询条件.Expression类提供了一系列用于设定查询条件的静态方法, 这些静态方法都返回Criterion实例,每个Criterion实例代表一个查询条件. Criteria的add()方法用于加入查询条件. 3.调用Criteria的list()方法执行查询语句.该方法返回List类型的查询结果,在 List集合中存放了符合查询条件的持久化对象. 比较运

MyBatis关联查询、多条件查询

1.一对一查询 任务需求; 根据班级的信息查询出教师的相关信息 1.数据库表的设计 班级表: 教师表: 2.实体类的设计 班级表: public class Classes { 9     //定义实体类的属性,与class表中的字段对应 10     private int id;            //id===>c_id 11     private String name;    //name===>c_name 13     /** 14      * class表中有一个tea

【Oracle】曾经的Oracle学习笔记(4-7)多表联合查询,子查询,动态条件查询

一.多表联合查询 二.子查询 三.动态条件查询 LESSON 4 Displaying Data from Multiple Tables-------------------------------------------------------- 查询s_emp表中最大的工资数,并且显示出这个最大工资数的员工名字 select last_name,max(salary)from s_emp; 多表查询 查询多张表的时候会产生笛卡尔积 为了防止笛卡尔积的产生,我们需要使用某些条件把两张表或多张

关键字查询和多条件查询

0616DBDA.class.php 代码 <?php /** * Created by PhpStorm. * User: Administrator * Date: 2016/6/16 * Time: 11:23 */ class DBDA { public $host="localhost";//服务器地址 public $uid="root" ;//用户名 public $pwd="";//密码 public $dbconnect;