多条件组合查询

方法一:

//多条件组合查询
    public List<Customer> findMoreCondition(Customer customer) {
        //1-使用hibernate模板里面find方法实现
        //拼接hql语句
        String hql = "from Customer where 1=1";
        //创建list集合,如果值不为空,就把值设置到list里面
        List<Object> p = new ArrayList<Object>();
        //判断条件值是否为空,如果不为空就拼接
        if(customer.getCustName()!=null && !"".equals(customer.getCustName())){
            hql += " and custName=?";
            p.add(customer.getCustName());
        }
        if(customer.getCustLevel()!=null && !"".equals(customer.getCustLevel())){
            hql += " and custLevel=?";
            p.add(customer.getCustLevel());
        }
        if(customer.getCustSource()!=null && !"".equals(customer.getCustSource())){
            hql += " and custSource=?";
            p.add(customer.getCustSource());
        }
        System.out.println("hql:"+hql);
        System.out.println("list:"+p);
        return (List<Customer>) this.getHibernateTemplate().find(hql, p.toArray());
    }

方法二(使用较多):

public List<Customer> findMoreCondition(Customer customer) {
        //2.使用离线对象
        DetachedCriteria criteria = DetachedCriteria.forClass(Customer.class);
        //判断条件值是否为空
        if(customer.getCustName()!=null&&!"".equals(customer.getCustName())){
            //对属性设置值
            criteria.add(Restrictions.eq("custName", customer.getCustName()));
        }
        /*if(customer.getCustLevel()!=null && !"".equals(customer.getCustLevel())){
            criteria.add(Restrictions.eq("custLevel", customer.getCustLevel()));
        }*/
        if(customer.getCustSource()!=null && !"".equals(customer.getCustSource())){
            criteria.add(Restrictions.eq("custSource", customer.getCustSource()));
        }

        return (List<Customer>) this.getHibernateTemplate().findByCriteria(criteria);
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设有一个学生表(students)包含以下字段:id、name、age、gender、major、grade。 现在要查询年龄在18~22岁之间、专业为计算机或者数学、且年级为大三或大四的学生信息。 可以使用以下动态sql语句: ``` DECLARE @sql NVARCHAR(MAX) DECLARE @ageStart INT = 18 DECLARE @ageEnd INT = 22 DECLARE @major1 NVARCHAR(20) = '计算机' DECLARE @major2 NVARCHAR(20) = '数学' DECLARE @grade1 INT = 3 DECLARE @grade2 INT = 4 SET @sql = 'SELECT id, name, age, gender, major, grade FROM students WHERE 1=1 ' IF @ageStart IS NOT NULL AND @ageEnd IS NOT NULL SET @sql += 'AND age BETWEEN ' + CAST(@ageStart AS NVARCHAR(2)) + ' AND ' + CAST(@ageEnd AS NVARCHAR(2)) + ' ' IF @major1 IS NOT NULL OR @major2 IS NOT NULL SET @sql += 'AND major IN (''' + @major1 + ''', ''' + @major2 + ''') ' IF @grade1 IS NOT NULL OR @grade2 IS NOT NULL SET @sql += 'AND grade IN (' + CAST(@grade1 AS NVARCHAR(2)) + ', ' + CAST(@grade2 AS NVARCHAR(2)) + ') ' PRINT @sql -- 可以查看生成的sql语句 EXEC(@sql) -- 执行查询 ``` 解析: - 先定义一个变量 @sql,用于存储动态生成的sql语句。 - 定义多个条件变量,用于存储查询条件的值。 - 初始时,@sql 只包含一个 WHERE 1=1,这个条件是为了方便后面的条件拼接。 - 判断每个条件变量是否为 NULL,如果不是则拼接对应的查询条件。 - 查询条件使用 BETWEEN、IN 等关键字,需要注意值的类型转换。 - 最后执行动态生成的sql语句。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值