MySQL中or用法及mybatis or用法详解

 更新时间:2024年05月31日 17:19:03   作者:MissYou-Coding  
在SQL查询语句中,OR关键字用于连接两个或多个条件,表示满足其中一个条件即可,当使用OR时,如果第一个条件为真,则不会检查第二个条件;如果第一个条件为假,则会检查第二个条件,这篇文章主要介绍了MySQL中or用法及mybatis or用法总结,需要的朋友可以参考下

1.MySql中OR的用法

场景:筛选某表中,姓“张”并且为“组别1”或者是“组别2”的客户!(意在组1和组2中姓张客户的集合!)
错误sql:select * from 表 where name like ‘张%’ and group = ‘1’ or group = ‘2’;
错误原因:这里查的是组1中姓张的客户和组2的所有客户!
正确sql:select * from 表 where name like ‘张%’ and (group = ‘1’ or group =‘2’);
备注:要搞清楚是哪个条件和哪个条件“或”关系!
### 小结:
在SQL查询语句中,OR关键字用于连接两个或多个条件,表示满足其中一个条件即可。当使用OR时,如果第一个条件为真,则不会检查第二个条件;如果第一个条件为假,则会检查第二个条件。

例如,假设有一个名为employees的表,包含以下字段:id(员工ID)、name(员工姓名)和department(部门)。如果你想查询名字为"张三"的员工或者部门为"销售部"的员工,可以使用以下### 查询语句:SELECT * FROM employees WHERE name = '张三' OR department = '销售部';
这个查询语句将返回名字为"张三"的员工以及部门为"销售部"的员工的所有记录。

2.Mybatis中OR的用法

<if test="condition.labelFlagInt != null and condition.labelFlagInt.size() > 0">
    AND 1=1 AND
    <foreach collection="condition.labelFlagInt" item="flagInt" index="index">
        <choose>
            <when test="flagInt == 1">
                 (UNIX_TIMESTAMP(NOW()) &lt;= endTime AND ((endTime - UNIX_TIMESTAMP(NOW())) - ((endTime - createTime) * 0.2)) &gt;= 0)
            </when>
            <when test="flagInt == 2">
                 (UNIX_TIMESTAMP(NOW()) &lt; endTime AND (((endTime - UNIX_TIMESTAMP(NOW())) - ((endTime - createTime) * 0.2)) &lt;= 0))
            </when>
            <when test="flagInt == 3">
                 (UNIX_TIMESTAMP(NOW()) &gt;= endTime)
            </when>
        </choose>
        <if test="index &lt; condition.labelFlagInt.size() - 1">OR</if>
    </foreach>
</if>

这段代码的作用是根据condition.labelFlagInt列表中的值生成一个SQL查询语句的条件部分。具体来说:

  • condition.labelFlagInt是一个整数列表,表示不同的条件标志。
  • 如果condition.labelFlagInt不为空且其大小大于0,则执行以下操作:
    • 添加AND 1=1到查询语句中,这是一个恒成立的条件,确保至少有一个记录满足条件。
    • 使用<foreach>标签遍历condition.labelFlagInt列表中的每个元素。对于每个元素,根据其值选择相应的条件表达式。
  • 如果值为1,则生成一个条件表达式,判断当前时间是否在指定的时间范围内。
  • 如果值为2,则生成一个条件表达式,判断当前时间是否小于指定的时间范围。
  • 如果值为3,则生成一个条件表达式,判断当前时间是否大于等于指定的时间范围。
  • 在每个条件表达式之间添加OR关键字,表示满足任意一个条件即可。
  • 最后,如果还有更多的元素需要处理,则在最后一个条件表达式之后添加OR关键字。

这样,根据condition.labelFlagInt列表中的值,生成的查询语句将包含相应的条件表达式,用于筛选符合条件的记录。

到此这篇关于MySQL中or用法及mybatis  or用法总结的文章就介绍到这了,更多相关mysql or用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 关于mysql时间区间问题浅析

    关于mysql时间区间问题浅析

    在很多地方都使用到了mysql的日期查询,下面这篇文章主要给大家介绍了关于mysql时间区间问题的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • mysql索引失效的几种情况分析

    mysql索引失效的几种情况分析

    这篇文章主要给大家介绍了关于mysql索引失效的情况,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • SQL实现LeetCode(183.从未下单订购的顾客)

    SQL实现LeetCode(183.从未下单订购的顾客)

    这篇文章主要介绍了SQL实现LeetCode(182.从未下单订购的顾客),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • mysql慢查询操作实例分析【开启、测试、确认等】

    mysql慢查询操作实例分析【开启、测试、确认等】

    这篇文章主要介绍了mysql慢查询操作,结合实例形式分析了mysql慢查询操作中的开启、测试、确认等实现方法及相关操作技巧,需要的朋友可以参考下
    2019-12-12
  • Mysql中的查询加强和多表查询详解

    Mysql中的查询加强和多表查询详解

    这篇文章主要介绍了Mysql中的查询加强和多表查询详解,在MySQL中,查询加强主要包括使用索引、优化查询语句和使用存储过程等方面,通过创建适当的索引,可以大大提高查询的效率,需要的朋友可以参考下
    2023-10-10
  • MySQL索引最左匹配原则实例详解

    MySQL索引最左匹配原则实例详解

    最左匹配原则就是指在联合索引中,如果你的SQL语句中用到了联合索引中的最左边的索引,那么这条SQL语句就可以利用这个联合索引去进行匹配,下面这篇文章主要给大家介绍了关于MySQL索引最左匹配原则的相关资料,需要的朋友可以参考下
    2022-09-09
  • 前端传参数进行Mybatis调用mysql存储过程执行返回值详解

    前端传参数进行Mybatis调用mysql存储过程执行返回值详解

    这篇文章主要介绍了前端传参数进行Mybatis调用mysql存储过程执行返回值详解,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • 分析一个MySQL的异常查询的案例

    分析一个MySQL的异常查询的案例

    这篇文章主要介绍了分析一个MySQL的异常查询的案例,主要是针对索引方面的操作问题,需要的朋友可以参考下
    2015-05-05
  • MySQL中常见的几种日志汇总

    MySQL中常见的几种日志汇总

    这篇文章主要给大家介绍了关于MySQL中常见的几种日志,文中通过实例代码结束的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-08-08
  • MySQL配置文件my.ini的使用解读

    MySQL配置文件my.ini的使用解读

    这篇文章主要介绍了MySQL配置文件my.ini的使用解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12

最新评论