Foxnic-SQL (3) —— 条件表达式(ConditionExpr)

LeeFJ
• 阅读 324

Foxnic-SQL (3) —— 条件表达式(ConditionExpr)

条件表达式

  条件表达式 ConditionExpr 的作用就是完成查询条件的拼装。ConditionExpr 支持自由拼装和指定字段的拼装。自由拼装类似 Expr 的使用方式,并不进行语义或语法的校验。指定字段的拼装,略微严格一点,它会进行简单的字段和值忽略的校验。

  本文中的示例代码均可在 https://gitee.com/LeeFJ/foxnic-samples 项目中找到。

以下是示例代码:

/**
* 1、基础条件表达式
* */
public static void demo1(Integer valid, Integer age, Date createDate, String keyword) {

    // 1、自由条件表达式
    ConditionExpr conditionExpr1 = new ConditionExpr("valid=?", valid);
    // 加入条件,并用 and 连接
    conditionExpr1.and("age>?", age);
    // 加入条件,并用 or 连接,当参数都为 null 时,语句不接入
    conditionExpr1.orIf("(create_date>? and name=?)", createDate,keyword);
    // 指定语句开通的关键字
    conditionExpr1.startWithWhere();
    System.out.println("conditionExpr1 = "+conditionExpr1.getSQL());

    // 2、指定操作符的条件表达式
    ConditionExpr conditionExpr2 = new ConditionExpr();
    // 指定字段与条件操作符并字段判断是否忽略改条件
    conditionExpr2.andLike("name", keyword);
    // 指定字段与条件操作符,
    conditionExpr2.andGreaterThan("age", age);
    // 指定语句开通的关键字
    conditionExpr2.startWithSpace();
    System.out.println("conditionExpr2 = "+conditionExpr2.getSQL());

}

  由于 ConditionExpr 通常是作为 SQL 语句中的一部分,有时需要 AND 开头,有时又需要用 WHERE 开头,所以需要用 startWithXXX 方法指定其语句的开头关键字。

值忽略

  值忽略是指开发人员在拼接语句时会使用的条件判断。大多数情况下是,当接口没有传入值时,条件不加到SQL语句中。但有时候也需要忽略非 null 的值。例如前端传入固定值 all 表示全部选项,此时需要判断值是all时,条件不被连入SQL语句。
以下是示例代码:

/**
* 2、值忽略
* */
public static void demo2(Integer valid, Integer age, Date createDate, String keyword) {

    // 默认忽略 null
    ConditionExpr conditionExpr1 = new ConditionExpr("valid=?", valid);
    conditionExpr1.andIf("age>?",age);
    conditionExpr1.andIf("name like ?","%"+keyword+"%");
    conditionExpr1.andLike("name",keyword);
    System.out.println("conditionExpr1 = "+conditionExpr1.getSQL());

    // 指定忽略的值
    ConditionExpr conditionExpr2 = new ConditionExpr();
    conditionExpr2.ignore(null,"null","any","all").andEquals("name",keyword);
    System.out.println("conditionExpr2 = "+conditionExpr2.getSQL());

}

子类与变体

  ConditionExpr 继承自 ConditionExpression ,同样继承 ConditionExpression 类的还包括:SelectWhere、DeleteWhere、UpdateWhere、Having等,这些对象作为其它高级语句的自语句存在,在之后的 Select 语句、Update语句、Delete语句中将会使用到。

In语句

  In语句是where条件中一个非常重要的子句,但是直接使用String构建又比较繁琐,Foxnic-SQL中使用 In 这个表达式构建 in 语句。示例如下:

 /**
 * In 语句
 * */
public static void demoIn1(Integer valid) {

    // 1、快速指定值
    ConditionExpr conditionExpr1 = new ConditionExpr("valid=?", valid);
    // 快速构建 in 语句
    In in1=new In("id",1,2,4);
    conditionExpr1.and(in1);
    System.out.println("conditionExpr1 = "+conditionExpr1.getSQL());
    // 输出:conditionExpr1 = AND valid= 1 AND id IN ( 1 , 2 , 4 )

    // 2、传入 List
    List<String> els= Arrays.asList("apple","duck","cat");
    In in2=new In("id",els);
    // 把 in 转换成条件表达式
    ConditionExpr conditionExpr2=in2.toConditionExpr();
    conditionExpr2.and("valid=?",valid);
    System.out.println("conditionExpr2 = "+conditionExpr2.getSQL());
    // 输出:conditionExpr2 = AND id IN ( 'apple' , 'duck' , 'cat' ) AND valid= 1

    // 3、多字段的 In 语句构建
    List<Object[]> els1= new ArrayList<>();
    for (int i = 0; i < 4 ; i++) {
        els1.add(new Object[]{i, IDGenerator.getRandomString(6)});
    }
    In in3=new In(new String[]{"id","code"},els1);
    // 把 in 转换成条件表达式
    ConditionExpr conditionExpr3=in3.toConditionExpr();
    System.out.println("conditionExpr3 = "+conditionExpr3.getSQL());
    // 输出:conditionExpr3 = AND ( id , code ) IN ( ( 0 , '5oJ8Vu' ) , ( 1 , 'xx00J*' ) , ( 2 , 'Bhc7@W' ) , ( 3 , '=Wdx&9' ) )
}

小结:

  本节主要讲解了条件表达式 ConditionExpr 的概念和它的基本用法。另外 In 语句是我们在拼接 Where 条件时经常会用到的一个语句,Foxnic-SQL 也提供了快速构建的方法。

相关项目

  https://gitee.com/LeeFJ/foxnic
  https://gitee.com/LeeFJ/foxnic-web
  https://gitee.com/lank/eam
  https://gitee.com/LeeFJ/foxnic-samples

官方文档

  http://foxnicweb.com/docs/doc.html

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
SQL条件语句(IF, CASE WHEN, IF NULL)
1.IF  表达式:IF(expr1,expr2,expr3)  expr1条件,条件为true,则值是expr2,false,值就是expr3SELECTo.id,u.account,catagory.name,orderTime,detail.amount,periodtime,if(direc
xxkfz xxkfz
3年前
Mybatis查询的时候BigDecimal类型的值查询失效的解决办法
最近在使用Mybatis查询的时候,使用了BigDecimal类型的值进行查询,在控制台通过打印的sql发现,查询条件并没有拼接上去,导致查询失败。为了演示还原这个过程,特意写了一个简单的演示项目:比如:我现在查询productprice字段大于0的数据,数据库的数据如下所示:mapper.xml中配置如下:javaselecti
Stella981 Stella981
3年前
Mybatis 通用Crud
更新日志<!20161113更新start1新增批量操作数据方法:批量插入,根据条件删除,根据条件更新指定的列名字段值。2新增高级查询方法:可设置查询列,查询条件,排序,分页。3根据1、2更新接口。4更改dao接口方法实现方式,统一采用GeneralMapper.xml编写sql,弃用General
Wesley13 Wesley13
3年前
Oracle基于布尔的盲注总结
0x01decode 函数布尔盲注decode(字段或字段的运算,值1,值2,值3)这个函数运行的结果是,当字段或字段的运算的值等于值1时,该函数返回值2,否则返回3当然值1,值2,值3也可以是表达式,这个函数使得某些sql语句简单了许多使用方法:比较大小select
Stella981 Stella981
3年前
Scala系列4:轻松搞定Scala中for,if,while,块表达式等
0.条件表达式   条件表达式一般就是if表达式,if表达式可以根据给定的条件是否满足,根据条件的结果(真或假)决定执行对应的操作。scala条件表达式的语法和Java一样。0.1有返回值的if条件表达式_尖叫提示:_在scala中,跟Java不同,条件表达式也是有返回值的s
Stella981 Stella981
3年前
Elasticsearch Query DSL之Term level queries
简介term\_level查询操作的是存储在反向索引(倒排索引)中的准确词根,这些查询通常用于结构化数据,如数字、日期和枚举,而不是全文字段,无需进行分析(分词),termlevel查询类似于关系型数据库的(where条件过滤)。其查询模式如下:termquery查找包含指定字段中精确匹配查询字符串的文档。
Wesley13 Wesley13
3年前
MySQL 数据查询语言(DQL)& 事务控制语言(TCL)详解
一、数据查询语言(DQL)(重中之重)完整语法格式:select表达式1|字段,....\from表名where条件\\groupby列名\\having条件\\orderby列名
Wesley13 Wesley13
3年前
MySQL 数据类型以及约束条件
一,创建表的完整语法:语法:createtable表名(字段名1类型(宽度)约束条件,字段名2类型(宽度)约束条件,字段名3类型(宽度)约束条件);注意:1.在同一张表中,字段名不能相同2.宽度和约束条件可选,字段名和类型
京东云开发者 京东云开发者
4个月前
一站式统一返回值封装、异常处理、异常错误码解决方案—最强的Sping Boot接口优雅响应处理器
1.前言统一返回值封装、统一异常处理和异常错误码体系的意义在于提高代码的可维护性和可读性,使得代码更加健壮和稳定。统一返回值封装可以避免每一个接口都需要手工拼装响应报文;统一异常处理可以将异常处理的逻辑集中到一个地方,避免代码中出现大量的trycatch语
京东云开发者 京东云开发者
2个月前
一站式统一返回值封装、异常处理、异常错误码解决方案—最强的Sping Boot接口优雅响应处理器
1.前言统一返回值封装、统一异常处理和异常错误码体系的意义在于提高代码的可维护性和可读性,使得代码更加健壮和稳定。统一返回值封装可以避免每一个接口都需要手工拼装响应报文;统一异常处理可以将异常处理的逻辑集中到一个地方,避免代码中出现大量的trycatch语