MySQL为什么将“ TRUE或TRUE and FALSE”评估为true?
MySQL将“TRUE或TRUE和FALSE”评估为true,因为AND的优先级高于OR,即AND的评估优先于OR。
MySQL这样评估上述语句。AND运算符首先被评估-
(TRUE or (TRUE AND FALSE))
语句(TRUEANDFALSE)给出结果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)
热门推荐
10 同事调动的祝福语简短
11 新娘对伴娘祝福语简短
12 妈妈生日祝福语简短温暖
13 小红书生日祝福语简短
14 求助短信生日祝福语简短
15 打游戏通关祝福语简短
16 孙媳妇祝福语简短
17 伤者出院祝福语简短大全
18 汤姆猫祝福语简短霸气