动态SQL条件

说明

hsweb定义了一种支持动态条件的数据结构:

{  //where name like 张%
    terms:[
        {
            column:"name", //属性名或者列名
            value:"张", //值,为null或者为""时,此条件将被忽略
            type:"and", // 连接类型,and 或者 or
            termType:"like", // like
            options:["startWith"], //可选项,不同的termType支持不同.
            terms:[
                //嵌套,结构同上
                
            ]
        }
    ]
}

对应的Java类有: QueryParamEntityUpdateParamEntityDeleteParamEntity

DSL

hsweb提供了通过DSL的方式来构造上述结构,用例:

如果继承了GenericEntityService的类可以直接使用DSL进行查询,修改,删除操作

//select * from table where name = ? limit 0,20
createQuery().where("name",name).list()
// select * from table where name like ?||'%';
// 构造并调用其他的dao
DefaultDSLQueryService.createQuery(userDao)
                .where("name$like$startWith",name)
                .listNoPaging();

上述例子中 name$like$startWith的含义: name(列), like(条件),startWith(条件选项)

默认支持的SQL条件

termType

SQL

DSL

说明

is 或者 eq

=

.is()

等于

not

!=

.not()

不等于

gt

>

.gt()

大于

lt

<

.lt()

小于

gte

>=

.gte()

大于等于

lte

<=

.lte()

小于等于

like

like

.like()

模糊匹配.支持options

  1. reverse 反转,如: ? like name

  2. startWith: like ?||%

  3. endWith: like %||?

nlike

not like

.notLike()

同like

in

in

.in()

值可以为以下格式:

  1. 1,2,3,4 字符串以半角逗号分割.

  2. [1,2,3,4] 集合.

nin

not in

.notIn()

同in

isnull

is null

.isNull()

为null

notnull

not null

.notNull()

不为null

empty

= ''

.isEmpty()

为空字符

nempty

!=''

.notEmpty()

不为字符

bwt

between

.between()

在之间

nbwt

not between

.notBetween

不在之间

自定义SQL条件

上述默认支持的SQL条件其实就是用来定义列与条件的拼接方式。在某些场景,我们可能需要定义一些通用的查询条件。

例如: 根据部门ID 查询所有此部门下所有人员的数据,而且有很多功能都要使用此条件。

按照以前的方式,需要在各个需要使用此查询条件的功能里 添加Dao方法或者修改查询配置

hsweb提供了SQL条件的拓展功能,用于添加特殊的查询条件。让自定义的条件用起来就像 like ,> , <一样方便。

创建拓展类

//AbstractSqlTermCustomer提供了一些便利的方法
@org.springframework.stereotype.Component //注入到spring自动开启支持此条件
public class UserInDepartmentTerm extends AbstractSqlTermCustomizer{

    @Override
    public String getTermType() {
        //对应Term参数中的属性termType
        return "user-in-dept";
    }

    @Override
    public Dialect[] forDialect() {
        //对特定对数据库类型生效,返回null时对全部支持对数据库类型生效
        return null;
    }

    @Override
    public SqlAppender accept(String wherePrefix, Term term, RDBColumnMetaData column, String tableAlias) {
        //当传入了my-term条件对时候,会调用此方法进行拼接
        //对传入对参数进行转换,此步骤为必须的
       ChangedTermValue termValue =createChangedValue(term);
        
       //转换参数,将参数转为集合,以支持in查询. 
       List<Object> idList = BoostTermTypeMapper.convertList(column, termValue.getOld());
        
       SqlAppender appender=  new SqlAppender();
      
       appender.add(createColumnName(column,tableAlias),"in (select user_id from user_department where t_id");
        
        //根据参数的数量,构造对应的=或者in条件
       Object newValue= appendCondition(idList,wherePrefix,appender);
        
       appender.add(")");
       //设置新的值到条件中
       termValue.setValue(newValue);
        
        return appender;
    }
}

使用:

// where user_id in(select user_id from user_department where t_id = ? )
createQuery().where("userId$user-in-dept","test")

这样,无需修改其他任何配置,即可支持查询任何表里指定部门下用户的数据了。

组织架构功能中,提供了一些已经拓展好的SQL条件。

Last updated