oracle 临时表内存表,Oracle临时表之临时表空间组(TTG)

在Oracle中,temp犹如win下的虚拟内存和unix下的swap分区TTG是10g引入的概念,目的就是为了减少IO竞争只有临时表空间可以定组,普

环境:

sys@ORCL> select * from v$version;

BANNER

----------------------------------------------------------------

Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod

PL/SQL Release 10.2.0.1.0 - Production

CORE 10.2.0.1.0 Production

TNS for Linux: Version 10.2.0.1.0 - Production

NLSRTL Version 10.2.0.1.0 - Production

在Oracle中,temp犹如win下的虚拟内存和unix下的swap分区

TTG是10g引入的概念,目的就是为了减少IO竞争

只有临时表空间可以定组,普通的表空间无法定组

对待TTG就像对待单个临时表空间一样,,无甚区别

TTG本身不能被创建,它随着temp的加入而创建,temp的脱离而删除

alter tablespace temp tablespace group '';

我们知道一个用户只能使用一个临时表空间,而一个临时表空间中只存在一个临时段

当一个session在使用临时段时,其他session再请求临时段时需要等到拥有该临时段的session使用完毕之后才能使用

而临时表空间组的出现大大改善了同一用户并发session对临时段的争夺

因为临时表空间组的出现使用户能够使用多个临时表空间了

下面作个简单测试

sys@ORCL> create temporary tablespace temp1 tempfile size 20M tablespace group tempg;

Tablespace created.

sys@ORCL> create temporary tablespace temp2 tempfile size 20M tablespace group tempg;

Tablespace created.

sys@ORCL> create temporary tablespace temp3 tempfile size 20M tablespace group tempg;

Tablespace created.

sys@ORCL> alter database default temporary tablespace tempg;

Database altered.

sys@ORCL> drop tablespace temp;

Tablespace dropped.

sys@ORCL> select * from dba_tablespace_groups;

GROUP_NAME TABLESPACE_NAME

------------------------------ ------------------------------

TEMPG TEMP1

TEMPG TEMP2

TEMPG TEMP3

sys@ORCL> alter user hr temporary tablespace tempg;

User altered.

sys@ORCL> conn hr/hr

Connected.

hr@ORCL> create table t as select * from dba_objects;

Table created.

hr@ORCL> begin

2 for i in 1..4

3 loop

4 insert into t select * from t;

5 end loop;

6 commit;

7 end;

8 /

PL/SQL procedure successfully completed.

hr@ORCL> create table tt as select * from t;

Table created.

分别打开两个session以用户hr登录对表t和tt同时进行排序,之后通过如下查询监视对临时表空间的使用情况

sys@ORCL> select operation_type ,sql_id , tablespace,tempseg_size,number_passes from v$sql_workarea_active;

OPERATION_ SQL_ID TABLESPACE TEMPSEG_SIZE NUMBER_PASSES

---------- ------------- ------------------------------ ------------ -------------

SORT (v2) b7q3tuybvatbt temp1 0

SORT (v2) cn7ucn092pg8s temp3 0

sys@ORCL> select sql_text from v$sql where sql_id in (select sql_id from v$sql_workarea_active);

SQL_TEXT

---------------------------------------------

select object_id from t order by object_id desc

select object_id from tt order by object_id desc

发现来自同一用户hr的不同session同时排序时使用了同一临时表空间组内的不同临时表空间

这样大大减少了之前同一用户只能使用一个临时表空间而产生的请求临时段的等待时间

logo.gif 本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python是一种高级编程语言,它具有简单易学、可读性强的特点,被广泛应用于各种领域的软件开发。以下是Python的一些特点和用途: 1. 简单易学:Python语法简洁清晰,易于理解和学习,适合初学者入门。 2. 面向对象:Python支持面向对象编程,可以使用类和对象来织和管理代码。 3. 大量的库和框架:Python拥有丰富的标准库和第三方库,可以满足各种需求,如数据分析、Web开发、机器学习等。 4. 跨平台:Python可以在多个操作系统上运行,包括Windows、Linux和MacOS等。 5. 动态类型:Python是一种动态类型语言,变量的类型在运行时确定,不需要显式声明。 6. 解释型语言:Python是解释型语言,代码在运行之前不需要编译,可以直接执行。 7. 开源社区活跃:Python拥有庞大的开源社区,提供了丰富的资源和支持。 Python可以用于各种任务,包括但不限于: - Web开发:使用框架如Django或Flask来构建网站和Web应用程序。 - 数据分析和科学计算:使用库如NumPy、Pandas和Matplotlib进行数据处理和可视化。 - 人工智能和机器学习:使用库如TensorFlow和PyTorch进行机器学习和深度学习的开发。 - 自动化和脚本编写:使用Python编写脚本来自动执行重复性任务。 - 网络爬虫:使用库如Scrapy来提取网页数据。 - 游戏开发:使用库如Pygame来开发2D游戏。 希望以上介绍对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值