• 数据库临时表(Temporary Table)


    当涉及到临时数据存储的需求时,SQL Server 提供了临时表(Temporary Table)的概念。临时表是存储在 tempdb 数据库中的一种特殊类型的表,它在会话结束后或者显式删除时自动被删除。

    临时表有以下两种类型:

    1. 局部临时表(Local Temporary Table):只在当前连接的会话中可见,其他连接的会话无法访问。

    2. 全局临时表(Global Temporary Table):在所有连接的会话都可见,但只有创建该表的会话可以修改或删除。

    对于临时表,你可以使用两种不同的方式进行操作

    1. 使用 CREATE TABLE 语句先创建临时表,然后使用 INSERT INTO 语句将数据插入到临时表中。这种方式适用于你已经知道临时表的结构,并且希望在多次查询中重复使用临时表。

    2. 使用 SELECT INTO 语句将查询结果直接插入到临时表中,而不需要提前创建临时表。这种方式更适合一次性的临时性查询,不需要重复使用临时表。

    1、典型的临时表创建语法如下:

    -- 创建局部临时表
    CREATE TABLE #temp_table
    (
        column1 data_type,
        column2 data_type,
        ...
    )
    
    -- 创建全局临时表
    CREATE TABLE ##temp_table
    (
        column1 data_type,
        column2 data_type,
        ...
    )
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    2、快速创建

    如果你想把查询出来的数据插入到临时表中,可以使用以下方式:

    SELECT column1, column2, ...
    INTO #temp_table
    FROM your_table
    WHERE your_conditions
    
    • 1
    • 2
    • 3
    • 4

    这样,查询的结果将会被存储在新创建的临时表 #temp_table 中,而不需要提前创建临时表。

    需要注意的是,临时表的表名前需要加上 ### 作为前缀,以标识为临时表。临时表的使用方式与常规表相同,可以执行各种 SQL 操作(如 SELECT、INSERT、UPDATE、DELETE 等)。

    以下是一些关于临时表的常见用法:

    1. 临时存储数据:可以在临时表中存储中间结果,以供后续查询或计算使用。

    2. 执行复杂的查询:将中间结果存储在临时表中,然后在复杂的查询中使用该临时表。

    3. 加速查询:通过创建适当的索引和统计信息,可以提高临时表上的查询性能。

    4. 分解复杂的逻辑:通过在临时表中暂存数据,可以分解复杂的逻辑为多个简单步骤。

    使用临时表时需要注意以下事项:

    1. 临时表的作用域限制:临时表只在创建它的会话中可见,对其他会话不可见。

    2. 临时表的生命周期:临时表在会话结束后自动删除,或者显式使用 DROP TABLE 语句删除。

    3. 数据的存储与查询:可以使用 INSERT 语句将数据插入临时表,使用 SELECT 语句查询临时表的内容。

    4. 表结构的保持:临时表的结构在会话期间保持不变,但可使用 ALTER TABLE 语句更改表结构。

    插入数据

    要往临时表中添加数据,你可以使用 INSERT INTO 语句将数据插入临时表。以下是一个示例:

    -- 创建一个局部临时表
    CREATE TABLE #temp_table
    (
        column1 data_type,
        column2 data_type,
        ...
    )
    
    -- 向临时表中插入数据
    INSERT INTO #temp_table (column1, column2, ...)
    VALUES (value1, value2, ...)
    
    -- 可以一次插入多行数据
    INSERT INTO #temp_table (column1, column2, ...)
    VALUES 
        (value1, value2, ...),
        (value3, value4, ...),
        ...
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    在 INSERT INTO 语句中,你需要提供要插入的列名和所对应的值。如果你想一次插入多行数据,可以在 VALUES 子句中使用逗号分隔的值列表。

    示例中的 value1、value2 等代表你要插入的具体值。你需要根据实际情况替换它们,并确保它们与在临时表中定义的列的数据类型相匹配。

    可以多次使用 INSERT INTO 语句来向临时表中插入多行数据。插入的数据将会累积在临时表中。

    需要注意的是,在会话结束后,临时表中的数据将被自动删除,因此你需要在每个会话中重新插入所需的数据。

  • 相关阅读:
    ASP.NET Core 6框架揭秘实例演示[24]:中间件的多种定义方式
    Linux——Linux驱动之iMX6ULL平台下串口UART驱动实现RS232数据通信开发实战(UART驱动框架、源码分析、串口应用程序编写)
    Vue响应式数据的判断
    UserAgentUtils 用于获取 Browser和Device信息
    Vue 组件之间的通信
    MyBatis的缓存,一级缓存,二级缓存
    申请国外博士后的常识
    【力扣 Hot100 | 第六天】4.21(最长连续序列)
    Trace 在多线程异步体系下传递最佳实践
    Leetcode 位运算
  • 原文地址:https://blog.csdn.net/qq_39034148/article/details/132811697