Skip to content

SQL IN 运算符


IN 运算符允许您在 WHERE 子句中指定多个值。

IN 运算符是多个 OR 条件的简写。

SQL IN 语法

sql
SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1, value2, ...);

或者

sql
SELECT column_name(s)
FROM table_name
WHERE column_name IN (SELECT STATEMENT);

演示数据库


在本教程中,我们将使用著名的 Northwind 示例数据库。

以下数据选取自"Customers" 表:

CustomerIDCustomerNameContactNameAddressCityPostalCodeCountry
1Alfreds FutterkisteMaria AndersObere Str. 57Berlin12209Germany
2Ana Trujillo Emparedados y heladosAna TrujilloAvda. de la Constitución 2222México D.F.05021Mexico
3Antonio Moreno TaqueríaAntonio MorenoMataderos 2312México D.F.05023Mexico
4Around the HornThomas Hardy120 Hanover Sq.LondonWA1 1DPUK
5Berglunds snabbköpChristina BerglundBerguvsvägen 8LuleåS-958 22Sweden

IN 操作符实例


以下 SQL 语句选取位于"Germany","France"和"UK"的所有客户:

代码示例:

sql
SELECT * FROM Customers
WHERE Country IN ('Germany', 'France', 'UK');

以下 SQL 语句选取不在"Germany","France"或"UK"中的所有客户:

代码示例:

sql
SELECT * FROM Customers
WHERE Country NOT IN ('Germany', 'France', 'UK');

以下 SQL 语句选取来自同一国家的所有客户作为供应商:

代码示例:

sql
SELECT * FROM Customers
WHERE Country IN (SELECT Country FROM Suppliers);