首页 >数据库 >mysql教程 >如何在 SQL 中高效创建和填充临时表?

如何在 SQL 中高效创建和填充临时表?

DDD
DDD原创
2025-01-02 19:13:41674浏览

How Can I Efficiently Create and Populate a Temporary Table in SQL?

在 SQL 中创建临时表:快速概述

您的查询旨在创建一个名为“temp1”的临时表并用数据填充它具有特定的“register_type”(“%gen%”)。但是,问题是由于使用“CREATE TABLE”而不是“CREATE TABLE AS”而产生的。

正确的方法

创建临时表并填充它对于查询中的数据,您应该使用“CREATE TABLE AS”:

CREATE TEMP TABLE temp1 AS
SELECT dataid
     , register_type
     , timestamp_localtime
     , read_value_avg
FROM   rawdata.egauge
WHERE  register_type LIKE '%gen%'
ORDER  BY dataid, timestamp_localtime;

This命令在内存中创建一个临时表,并用查询结果行填充它。它类似于常规表,但驻留在 RAM 中。

了解 PostgreSQL 中的临时表

临时表在当前会话中可见,并在会话终止时消失。或者,您可以指定“ON COMMIT DROP”,让它们在事务结束时消失。

临时表的替代方案

对于动态临时表,请考虑使用“CREATE VIEW”,提供持续更新的数据快照。但是,对于静态快照,首选“CREATE TABLE AS”。

虽然“SELECT INTO”也可以创建临时表,但不鼓励这样做。相反,请使用“CREATE TABLE AS”。 “CREATE TABLE LIKE”仅复制表结构,而不复制数据。

对于仅在单个查询中使用的临时表,CTE 或子查询中的“派生表”提供了轻量级替代方案。

以上是如何在 SQL 中高效创建和填充临时表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn