909422229_Jeesite4使用sqlMap添加查询条件AND、OR

一、在jeesite中简单使用SqlMap函数直接添加查询条件可以减少我们的工作量,加快开发效率,下面介绍一下遇到的坑坑洼洼。

本人在网上查了也没有查到,文档也没有去细看,直接开始搞了。

AND写法如下:

sqlMap.getWhere().and("字段", QueryType.NE_FORCE, 传入条件, 占位符:2,3,4,5,6自己累加);

OR写法如下:

sqlMap.getWhere().andBracket("字段", QueryType.EQ_FORCE, 参数, 占位符)
					.or("字段", QueryType.EQ_FORCE, 参数, 占位符+1).endBracket();

这里需要注意的是后面需要有一个endBreacket()方法。这是说明or结束用 “)”结尾,否则是不会结尾,查询报错。 

在多个写法中更加注意,这个endBreacket()需要注意。

业务:查询type类型,or多个,例如or:1,2,3,4,5.结束后在状态字段status中or多个,例如or:1,2
  QueryWhere where = sqlMap.getWhere();
		if(typeList !=null && typeList.size()>0) {
			String string = typeList.get(0);
			if(!StringHelper.isNullOrEmptyString(string)) {
				where.andBracket("award_type", QueryType.EQ_FORCE, string, 2);
			}
		}
		if(typeList !=null) {
			for(int i = 1;i<typeList.size();i++) {
				String string = typeList.get(i);
				if(!StringHelper.isNullOrEmptyString(string)) {
					where.or("award_type", QueryType.EQ_FORCE, string, i+2);
				}
			}
		}
		sqlMap.getWhere().andBracket("staTus", QueryType.EQ_FORCE, status1, 2)
		.or("staTus", QueryType.EQ_FORCE, status2, 3).endBracket();
		where.endBracket();

这时查询真正的sql是报错的,如下:
AND (
    a.award_type = ?
    OR a.award_type = ?
    OR a.award_type = ?
    OR a.award_type = ?
    OR a.award_type = ?
    OR a.award_type = ?
    OR a.award_type = ?
    OR a.award_type = ?
  AND (a.staTus = ?
    OR a.staTus = ?)

这是没有使用endBracket()方法造成的问题,解决办法如下:

QueryWhere where = sqlMap.getWhere();
		if(typeList !=null && typeList.size()>0) {
			String string = typeList.get(0);
			if(!StringHelper.isNullOrEmptyString(string)) {
				where.andBracket("award_type", QueryType.EQ_FORCE, string, 2);
			}
		}
		if(typeList !=null) {
			for(int i = 1;i<typeList.size();i++) {
				String string = typeList.get(i);
				if(!StringHelper.isNullOrEmptyString(string)) {
					where.or("award_type", QueryType.EQ_FORCE, string, i+2);
				}
			}
		}
		where.endBracket(2); //重载参数,告诉在这里进行加结束括号:“)”
        //下面进行另一个字段的多个OR查询。
		sqlMap.getWhere().andBracket("staTus", QueryType.EQ_FORCE, status1, 2)
		.or("staTus", QueryType.EQ_FORCE, status2, 3).endBracket();
		where.endBracket();//结束括号:“)”

上面查询结果出来了,是正确的。在type后加了")".

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

75888丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值