3.2 AND 运算符

在本教程中,将学习如何使用 MySQL AND运算符组合多个布尔表达式以形成多个条件来过滤数据。

MySQL AND 运算符简介

AND运算符是组合两个或多个布尔表达式的逻辑运算符,只有当两个表达式求值为true时才返回true。如果两个表达式中的一个求值为false,则AND运算符返回false

WHERE boolean_expression_1 AND boolean_expression_2

以下说明AND运算符组合truefalsenull时的结果。

-

TRUE

FALSE

NULL

TRUE

TRUE

FALSE

NULL

FALSE

FALSE

FALSE

FALSE

NULL

NULL

FALSE

NULL

AND运算符通常用在SELECTUPDATEDELETE语句的WHERE子句中以形成布尔表达式。AND运算符也用于INNER JOINLEFT JOIN子句的连接条件。

当求值具有AND运算符的表达式时,MySQL 会计算表达式的其余部分,直到可以确定结果为止。该功能称为短路求值。请参见以下示例。

SELECT 1 = 0 AND 1 / 0 ;

执行上面查询时,得到以下结果 -

mysql> SELECT 1 = 0 AND 1 / 0 ;
+-----------------+
| 1 = 0 AND 1 / 0 |
+-----------------+
|               0 |
+-----------------+
1 row in set

请注意,在 MySQL 中,0被认为是false,非零被视为true

MySQL 只计算表达式1 = 0 AND 1/0的第一部分1 = 0,因为表达式1 = 0返回false,所以 MySQL 得出结论:整个表达式的结果是false。 MySQL 不对表达式的剩余部分求值,即不对1/0进行求值; 如果对1/0进行求值,它将发出一个错误消息,因为除以零错误。

MySQL AND 运算符示例

下面使用示例数据库中的customers表进行演示。customers表的结构如下所示 -

以下声明选择国家是USACA的客户。我们在WHERE子句中使用AND运算符。

执行上面查询得到以下结果 -

使用AND运算符,可以组合两个以上的布尔表达式。例如,以下查询返回位于美国加州的客户,并且信用额度大于100K

执行上面查询语句,得到以下结果 -

在本教程中,我们向您展示了如何使用 MySQL AND运算符组合两个或多个表达式以形成WHERE子句的复合条件语句。

Last updated

Was this helpful?