这几天突然发现服务器变慢了,后去看,是临时表空间突然变得奇大,把硬盘空间都
给占用掉了,只好重新建立一个临时表空间,把以前的删除.
但增长速度还是很快.是否可以说明一下是什么原因会引起增长速度变得奇快.

解决方案 »

  1.   

    临时表空间增长太快,说明有大的数据查询
    特别是排序或者分组最好先把autoextend off
    alter database datafile 'XXX' autoextend off;
    以免空间增长查过物理存储
      

  2.   

    楼上说的对。大数据量的查询中,使用了order by , join等。
      

  3.   

    检查有没有超大的查询或transaction
      

  4.   

    设置为不自动增长你应该是有大量的排序操作(order by group by等等)
      

  5.   

    [kinglht] 兄:
    为什么我临时表并没有见到它的使用量减少呢,只看到增加.
      

  6.   

    可能是以下几个方面的原因造成的。
            1. 没有为临时表空间设置上限,而是允许无限增长。但是如果设置了一个上限,最后可能还是会面临因为空间不够而出错的问题,临时表空间设置太小会影响性能,临时表空间过大同样会影响性能,至于需要设置为多大需要仔细的测试。
            2.查询的时候连表查询中使用的表过多造成的。我们知道在连表查询的时候,根据查询的字段和表的个数会生成一个迪斯卡尔积,这个迪斯卡尔积的大小就是一次查询需要的临时空间的大小,如果查询的字段过多和数据过大,那么就会消耗非常大的临时表空间。
           3.对查询的某些字段没有建立索引。Oracle中,如果表没有索引,那么会将所有的数据都复制到临时表空间,而如果有索引的话,一般只是将索引的数据复制到临时表空间中。
           针对以上的分析,对查询的语句和索引进行了优化,情况得到缓解,但是需要进一步测试。       总结:
           1.SQL语句是会影响到磁盘的消耗的,不当的语句会造成磁盘暴涨。
           2.对查询语句需要仔细的规划,不要想当然的去定义一个查询语句,特别是在可以提供用户自定义查询的软件中。
           3.仔细规划表索引。