在 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中文网其他相关文章!