SQL 中针对多个字段使用 IN 操作符有两种方法:通过子查询或直接列出多个值。子查询用于从其他查询中检索值,而多个值可以用逗号分隔直接列出。IN 操作符检查给定值是否在指定值的列表中。

SQL 中多个字段中的 IN 用法
IN 操作符用于检查给定值是否在指定值的列表中。当需要检查多个字段时,可以在 IN 操作符中使用子查询或多个值。
子查询
子查询是一种嵌套查询,用于从数据库中检索数据。它可以在 IN 操作符中使用,将多个字段的值与其比较。语法如下:
<code class="sql">SELECT * FROM table_name
WHERE (column1, column2, ...) IN (
SELECT column1, column2, ... FROM subquery
);</code>例如:
<code class="sql">SELECT * FROM orders
WHERE (order_id, customer_id) IN (
SELECT order_id, customer_id FROM order_details
);</code>多个值
也可以在 IN 操作符中指定多个值,用逗号分隔。语法如下:
<code class="sql">SELECT * FROM table_name WHERE (column1, column2, ...) IN (value1, value2, ...);</code>
例如:
<code class="sql">SELECT * FROM customers
WHERE (first_name, last_name) IN ('John', 'Doe');</code>示例
考虑一个包含以下数据的表 orders:
| order_id | customer_id | product_id |
|---|---|---|
| 101 | 1 | 201 |
| 102 | 1 | 301 |
| 103 | 2 | 201 |
| 104 | 2 | 302 |
要找出订购了产品 201 或 302 的客户,可以使用 IN 操作符:
<code class="sql">SELECT * FROM orders WHERE (product_id) IN (201, 302);</code>
输出将是:
| order_id | customer_id | product_id |
|---|---|---|
| 101 | 1 | 201 |
| 102 | 1 | 301 |
| 103 | 2 | 201 |
| 104 | 2 | 302 |
以上就是sql中多个字段in的用法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号