通用SQL条件

平台使用可拓展的方式进行SQL条件构造,如: like,gt,lt等。

平台内置SQL条件

termTypeSQLDSL说明
is 或者 eq=.is()等于
not!=.not()不等于
gt>.gt()大于
lt<.lt()小于
gte>=.gte()大于等于
lte<=.lte()小于等于
likelike.like()模糊匹配. 需要自己将value拼接%.
nlikenot like.notLike()同like
inin.in()值可以为以下格式:1,2,3,4 字符串以半角逗号分割. [1,2,3,4] 集合.
ninnot in.notIn()同in
isnullis null.isNull()为null
notnullnot null.notNull()不为null
empty= ‘’.isEmpty()为空字符
nempty!=’’.notEmpty()不为字符
bwtbetween.between()在之间
nbwtnot between.notBetween不在之间
dev-groupexists(…..).where(“deviceId$dev-group”,groupId)按设备分组查询 (Pro)
dev-same-groupexists(…..).where(“deviceId$dev-same-group”,anotherDeviceId)查询同一个分组的设备,如果要包含此设备则使用: deviceId$dev-same-group$contains (Pro)
dev-tagexists(…..).where(“deviceId$dev-tag”,”tagKey:tagValue”)按标签查询,支持格式: key:value,[{“key”:”tagKey”,”value”:”tagValue”}]

自定义SQL条件构造器

新建一个类,继承AbstractTermFragmentBuilder,注解@Component注入到spring.

  1. @Component
  2. public class CustomTermBuilder extends AbstractTermFragmentBuilder{
  3. public CustomTermBuilder(){
  4. //custom 为条件标识,就像like一样
  5. super("custom","自定义查询条件");
  6. }
  7. public SqlFragments createFragments( String columnFullName, //列全名,查询条件对应的列名
  8. RDBColumnMetadata column, //列元数据
  9. Term term){ //条件
  10. return PrepareSqlFragments.of()
  11. .addSql("exists(select 1 from custom_table t where t.device_id =",columnFullName," and t.value = ?)")
  12. .addParameter(term.getValue());
  13. }
  14. }

在后端通用CRUD中使用

  1. repository.createQuery().where("deviceId$custom","1234").fetch();

在前端通用查询条件中使用

  1. {
  2. "where": "deviceId custom 1234"
  3. }

或者

  1. {
  2. "terms":[
  3. {
  4. "column":"deviceId",
  5. "termType":"custom",
  6. "value":"1234"
  7. }
  8. ]
  9. }