sql中where后面if语句的用法-SQL
SQL 中 WHERE 子句中的 IF 语句用法
WHERE 子句用于在 SQL 查询中过滤数据,仅返回满足指定条件的行。IF 语句可用于在 WHERE 子句中创建条件表达式,以便根据某个条件执行不同的操作。
IF 语句语法
WHERE IF(condition, true_value, false_value)
登录后复制
其中:
- condition:要评估的布尔表达式。
- true_value:如果条件为 true,则返回的值。
- false_value:如果条件为 false,则返回的值。
用法
IF 语句可以用于创建复杂的过滤条件,它可以在 WHERE 子句中执行以下操作:
- 将空值替换为另一个值。
- 根据条件返回不同的值。
- 基于不同的条件执行嵌套查询。
示例
将空值替换为默认值:
SELECT * FROM table_name WHERE IF(column_name IS NULL, 'N/A', column_name);
登录后复制
这将返回一个表,其中所有空值的 column_name 列都将替换为 "N/A"。
根据条件返回不同的值:
SELECT * FROM table_name WHERE IF(age >= 18, 'Adult', 'Underage');
登录后复制
这将返回一个表,其中 age 列的值大于等于 18 的行为 "Adult",小于 18 的行为 "Underage"。
基于不同的条件执行嵌套查询:
SELECT * FROM table_name WHERE IF(country = 'USA', (SELECT MAX(salary) FROM employees WHERE country = 'USA'), (SELECT MAX(salary) FROM employees WHERE country = 'UK'));
登录后复制
这将返回一个表,其中 salary 列的值为美国员工的最大工资,如果是英国员工,则为英国员工的最大工资。