Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > mysql or用法

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

作者: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列表中的值,生成的查询语句将包含相应的条件表达式,用于筛选符合条件的记录。

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

您可能感兴趣的文章:
阅读全文