在数据库操作中,VALUES 子句是一个非常有用的工具,它可以直接在查询中创建一组值。这种方式非常适合用于临时数据的展示、测试和处理。本文将详细介绍 VALUES 子句的用法,并列出支持该功能的主要数据库系统。

一、VALUES 子句的基本用法

VALUES 子句允许我们在 SQL 查询中直接定义一组行,每行包含多个值。然后可以通过查询这些值来进行数据操作,而无需创建实际的表。

基本语法
SELECT *
FROM (VALUES
    (value1, value2, ...),
    (value1, value2, ...)
) AS table_alias(column1, column2, ...);
示例

假设我们需要一个临时的数据集来表示性别信息,可以使用以下 SQL 语句:

SELECT *
FROM (VALUES
    (1, '男'),
    (2, '女'),
    (3, '保密')
) AS Gender(ID, Description);

运行上述查询将返回如下结果:

ID Description
1
2
3 保密
二、VALUES 子句的扩展用法

除了基本的行值定义,VALUES 子句还可以与其他 SQL 子句结合使用,以实现更复杂的数据操作。

与 INSERT 结合

VALUES 子句常用于 INSERT 语句中,以插入多行数据:

INSERT INTO Gender (ID, Description)
VALUES
    (1, '男'),
    (2, '女'),
    (3, '保密');
与 CTE 结合

可以将 VALUES 子句与公用表表达式(CTE)结合,以创建复杂查询:

WITH GenderCTE AS (
    SELECT *
    FROM (VALUES
        (1, '男'),
        (2, '女'),
        (3, '保密')
    ) AS Gender(ID, Description)
)
SELECT *
FROM GenderCTE
WHERE ID <> 3;

该查询将返回除 ID 为 3 以外的所有行。

三、支持 VALUES 子句的数据库系统

VALUES 子句是 SQL 标准的一部分,因此被许多主流的数据库管理系统(DBMS)所支持。以下是一些常见的数据库系统及其对 VALUES 子句的支持情况:

1. Microsoft SQL Server

SQL Server 完全支持 VALUES 子句,可以用于 SELECTINSERT 等语句中。

2. PostgreSQL

PostgreSQL 支持 VALUES 子句,并允许在 SELECTINSERT 以及 CTE 中使用。

3. MySQL

从 MySQL 8.0 开始,VALUES 子句得到了更好的支持,尤其是在 CTE 和复杂查询中。

4. SQLite

SQLite 也支持 VALUES 子句,可以在 SELECT 语句和 INSERT 语句中使用。

5. Oracle

Oracle 数据库支持 VALUES 子句,但其语法稍有不同,特别是在复杂查询中需要注意。

四、总结

VALUES 子句是一个强大的工具,允许我们在 SQL 查询中直接定义和使用一组值。它不仅简化了临时数据集的构建,还能与其他 SQL 子句结合使用,以实现复杂的数据操作。几乎所有主流的数据库系统都支持 VALUES 子句,使其成为 SQL 查询中不可或缺的一部分。无论是在数据插入、数据查询,还是数据操作中,VALUES 子句都提供了极大的便利和灵活性。

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐