首页 > 数据库 >数据库临时表的使用

数据库临时表的使用

时间:2023-09-26 11:57:17浏览次数:30  
标签:存储 临时 数据库 使用 查询 SQL 数据 select

一、什么是临时表

临时表就是用来暂时保存临时数据(亦或叫中间数据) 的一个数据库对象, 它和普通表有些类似, 然而又有很大区别。 它只能存储在临时表空间, 而非用户的表空间。 临时表是会话或事务级别的, 只对当前会话或事务可见。 每个会话只能查看和修改自己的数据。

临时表的分类:
事务级 (On Commit Delete Rows)
数据在 Transaction 期间有效一旦COMMIT后,rollback,断开连接,数据就被自动 TRUNCATE

创建方式:

SQL> create global temporary table t_tmp_tab (id number,name varchar2(20)) on commit delete rows;

Table created.

SQL> desc t_tmp_tab
Name Null  Type
----------------------------------------------------- -------- ------------------------------------
ID NUMBER
NAME VARCHAR2(20)

SQL> insert into t_tmp_tab select empno,ename from emp where deptno=10;

3 rows created.

SQL> select * from t_tmp_tab;

ID NAME
---------- --------------------
7782 CLARK
7839 KING
7934 MILLER

SQL> commit;

Commit complete.

#事务提交后,再次查询,数据已经被清空
SQL> select * from t_tmp_tab;

no rows selected

SQL>

 

session级 (On Commit Preserve Rows)
数据在 Session 期间有效一旦关闭了Session 或 Log Off 后,数据就被自动 TRUNCATE

创建方式:

SQL> create global temporary table s_tab_tmp (id number,name varchar2(20)) on commit preserve rows;

Table created.

SQL> insert into s_tab_tmp select empno,ename from emp where deptno=10;

3 rows created.

SQL> commit;

Commit complete.

SQL> select * from s_tab_tmp;

ID NAME
---------- --------------------
7782 CLARK
7839 KING
7934 MILLER

SQL> exit


#重新登录
#断开会话,重新连接后,数据被清空
SQL> select * from s_tab_tmp;

no rows selected

SQL>

 

二、临时表的应用场景

复杂查询优化:当需要进行复杂的数据查询和分析时,可以使用临时表来存储中间结果,以便后续查询使用。通过将中间结果存储在临时表中,可以减少查询的复杂性和提高性能。

数据筛选和过滤:临时表可以用于存储满足特定条件的数据子集。通过将数据筛选和过滤的结果存储在临时表中,可以简化后续的查询和操作,并提高查询的效率。

数据转换和清洗:在进行数据转换和清洗的过程中,临时表可以作为中间存储结构。可以将原始数据导入临时表中,对数据进行转换、清洗和规范化,然后将处理后的数据插入到目标表中。

大批量数据处理:当需要处理大量数据时,临时表可以作为临时存储结构来处理数据。可以将大量数据分批次导入到临时表中,然后对临时表中的数据进行批量处理,最后将结果导入到目标表或其他系统中。

过程性操作:临时表可用于存储在过程性操作中使用的临时数据。例如,在存储过程或函数中,可以使用临时表来存储中间结果,以便在过程执行过程中使用和处理。

会话级别的数据共享:临时表在同一个数据库连接会话中的多个查询之间共享数据。这种共享能力可以用于在一个会话中的多个查询中共享临时结果,从而提高查询的可读性和可维护性。

表关联和数据比较:临时表可以用于表关联操作和数据比较。可以将需要关联或比较的数据存储在临时表中,然后通过临时表进行连接操作或数据比较。

三、临时表的优缺点

优点:

临时性:临时表只在当前会话中存在,会话结束后自动销毁,不占用永久存储空间。这减少了数据库中的数据冗余,保持数据库的整洁性。

提高性能:通过使用临时表存储中间结果,可以优化复杂查询的性能。临时表提供了更好的可读性和可优化性,同时还可以通过索引等技术进一步提高查询性能。

共享数据:临时表在同一个会话中的多个查询之间共享数据,这使得复杂查询更易于编写和维护。它还可以在存储和检索数据方面提供更高的灵活性。

缺点:

数据丢失:临时表只在当前会话中存在,会话结束后数据会被自动清除。如果需要长期存储数据,临时表不适合使用。

资源占用:临时表占用数据库的内存和其他资源。当临时表的数据量较大或会话并发量较高时,可能会对数据库的性能和资源利用产生一定的影响。

命名冲突:临时表的命名通常以特定前缀或后缀来标识,以与普通表区分开。但如果命名不当,可能会导致与其他表发生命名冲突,造成意外的结果。

总结:在使用临时表时,需要根据具体的需求和场景权衡其优缺点,确保正确使用临时表的优势,并避免潜在的缺点。

四、clickhouse临时表的存储

ClickHouse临时表是存储在内存中的表,用于存储临时数据,仅在会话期间存在并可用。临时表的数据在内存中进行存储和处理,不会持久化到磁盘上

五、clickhouse临时表应用

1. 创建语法

CREATE TEMPORARY TABLE [IF NOT EXISTS] table_name
(
    name1 [type1] [DEFAULT|MATERIALIZED|ALIAS expr1],
    name2 [type2] [DEFAULT|MATERIALIZED|ALIAS expr2],
    ...
) [ENGINE = engine]

2. 使用示例

示例1

CREATE TEMPORARY TABLE IF NOT EXISTS t1
(
    name String not null,
    age UInt8 not null
) ENGINE = Memory
order by name;


insert into t1 (name, age) values ('a', 11),('b', 22);

select * from t1

注:临时表只能使用Memory引擎

执行结果:

 

示例2,复杂逻辑场景,可以这样用:

CREATE TEMPORARY TABLE IF NOT EXISTS temp_t as 
with t1 as(
    select * from numbers(5)
)
select * from t1;

select * from temp_t;

执行结果:

 

示例3,多个临时表:

CREATE TEMPORARY TABLE IF NOT EXISTS temp_t1 as 
with t1 as(
    select * from numbers(5)
)
select * from t1;

CREATE TEMPORARY TABLE IF NOT EXISTS temp_t2
(
    name String not null,
    age UInt8 not null
) ENGINE = Memory
order by name;

insert into temp_t2 (name, age) values ('a', 11),('b', 22);

select * from temp_t2,temp_t1

执行结果:

 

标签:存储,临时,数据库,使用,查询,SQL,数据,select
From: https://www.cnblogs.com/liuxuelin/p/17729760.html

相关文章

  • 免费ChatGPT使用,免费一键去除视频水印,有这免费的app就够用了
    ​大家好,我是小凉席,这款APP是我在大学期间试着做着玩的一款工具合集APP本来是想做着玩的,可是越做用户越多,直到现在群里那么多朋友支持,又给了我很大的动力来更新这款app从这款APP诞生到现在已经有两年时间了,一直秉持这  免费,无收费软件内工具有:视频去水印,图集去水印,视频转图片......
  • fastapi+tortoise-orm+redis+celery 多worker数据库连接
    我用fastapi在写接口,数据库orm用的是tortoise-orm,接口的数据库操作是正常的。现在加入了celery,但是每个celery在执行任务时,不能获取到数据库连接我想要每个worker获得数据库连接,但是不要每个任务都去连接一次,并在每个worker结束时,断开连接,但是不能断开其他worker的数据库连接from......
  • 如何教会小白使用API接口获取商品数据
    在当今的数字化时代,API接口已经成为数据获取的重要通道。API,全称应用程序接口,是一种预定义的软件组件,用于提供特定的功能或数据。通过使用API接口,我们可以轻松地从各种数据源获取信息,包括商品数据。本文将指导小白如何使用API接口获取商品数据,从申请API接口、使用API接口到实际应用......
  • 使用 Spring Integration 实现基于 Redis 的分布式锁以及踩坑
    背景分布式锁的应用场景应该还是蛮多的,这里就不赘述了。之前在开发中实现分布式锁都是自己基于Redis造轮子,虽然也不复杂并且自己实现一次能对分布式锁有更深的了解,但是终归有些麻烦。尤其是新项目需要的时候还得CV一次。然后在查询过程中(毫不意外地)发现Spring有现成的组......
  • 使用MAT比较多个heap dump文件
    参考文档:https://www.cnblogs.com/melody-emma/p/4914832.html 1.步骤 2.生成结果 3.对比效果 ......
  • Seata+naocs 使用
    1.环境seata1.5.2.  nacos2.1.0本地配置好nacos之后 新建一个seata的命名空间,seata需要使用  seata准备1:创建mysql的seata数据库 执行\seata-server-1.5.2\script\server\db\mysql.sql2:拷贝config.txt  从seata-server-1.5.2\script\config-center\confi......
  • 教程 | 使用 Apache SeaTunnel 同步本地文件到阿里云 OSS
    一直以来,大数据量一直是爆炸性增长,每天几十TB的数据增量已经非常常见,但云存储相对来说还是不便宜的。众多云上的大数据用户特别希望可以非常简单快速的将文件移动到更实惠的S3、OSS上进行保存,这篇文章就来介绍如何使用SeaTunnel来进行到OSS的数据同步。首先简要介绍一下......
  • 【快应用】如何在快应用中使用自定义指令
    ​ 【关键词】操作DOM、自定义指令 【问题背景】在快应用中,有些情况下我们需要对 DOM 元素进行访问,或者在元素创建、更新、销毁过程中处理相应的业务逻辑,通过快应用文档中现有的方法实现不了,我们需要使用自定义指令去完成我们想要的操作,这里就介绍下快应用中如何去使用自......
  • Maven——构建和使用私服
       代理仓库是所有人共享的,仓库组对多个宿主仓库进行编组。宿主仓库中存放的第三方资源指的是非开源的收费资源 ......
  • Mysql使用 jemalloc 内存分配器
    /usr/lib64/libjemalloc.so是一个动态链接库文件,它包含了jemalloc内存分配器的实现。jemalloc是一个通用的内存分配器,旨在为多线程应用程序提供优秀的性能。它通常被用在需要高效内存管理的应用程序中,如数据库服务器、Web服务器等。安装库文件这个库文件一般是通过系统的包......