为什么 MySQL 将“TRUE 或 TRUE 和 FALSE”评估为 true?

为什么 MySQL 将“TRUE 或 TRUE 和 FALSE”评估为 true?

数据库 2024-02-05 15:01:04 1年以前

MySQL将“TRUE or TRUE and FALSE”评估为true,因为AND比OR具有更高的优先级,即AND在OR之前被评估。

MySQL按照以下方式评估上述语句。首先评估AND运算符 −

(TRUE or (TRUE AND FALSE))

语句 (TRUE AND FALSE) 的结果是 FALSE。然后是第二个语句评估如下 -

(TRUE or FALSE)

上面的语句给出的结果为 TRUE。

让我们一一实现 -

mysql> select (TRUE AND FALSE);+------------------+| (TRUE AND FALSE) |+------------------+|                0 |+------------------+1 row in set (0.00 sec)

现在我们可以将上述结果放在AND条件的位置−

mysql> select (TRUE or FALSE);+-----------------+| (TRUE or FALSE) |+-----------------+|               1 |+-----------------+1 row in set (0.00 sec)

现在再次检查整个条件 −

mysql> select (TRUE or TRUE and FALSE);

这将产生以下输出 −

+--------------------------+| (TRUE or TRUE and FALSE) |+--------------------------+|                        1 |+--------------------------+1 row in set (0.00 sec)

文章版权声明:除非注明,否则均为网络转载文章,转载或复制请以超链接形式并注明出处。