使用复杂的 WHERE 子句时,通常需要将一个字段或一组字段与值列表进行比较。在比较元组的情况下,有多种选项可用。
带有硬编码值的 IN 子句
一种方法是在 IN 子句中使用硬编码值。但是,这对于大型表来说效率较低,因为每条记录都需要字符串连接和转换。
使用 VALUE 子句(标准 SQL)
标准的更高效选项SQL-92 数据库在 IN 运算符内使用 VALUES 子句。这涉及到将元组列表括在括号中并添加 VALUES 关键字。
SELECT * FROM mytable WHERE (group_id, group_type) IN ( VALUES ('1234-567', 2), ('4321-765', 3), ('1111-222', 5) );
数据库兼容性
需要注意的是,并非所有 SQL 都支持此语法产品。从 SQL Server 2022 开始,此功能被认为是计划外的。然而,PostgreSQL 和 SQLite 确实支持这种语法。
以上是如何有效比较 SQL 的 IN 子句中的元组?的详细内容。更多信息请关注PHP中文网其他相关文章!