ORA-01688:扩展ORACLE表空间操作

 

感谢分享:http://blog.itpub.net/31369373/viewspace-2150761/

https://blog.csdn.net/qq_41797451/article/details/80431390

https://blog.csdn.net/guo_cw/article/details/80530726

1、问题现象: 页面导入数据报错:ora-01688

ORA-01688:扩展ORACLE表空间操作

2、问题原因:

(1) ORA-01688: 无法通过1024 表空间扩展 ,这个错误表明表空间已使用完,且无法分配新的空间。这是因为表空间扩展方式为手动模式,而非自动模式;

3、解决法:

(1)、确定是哪个表空间用满了(查看表空间利用率):

SELECT c.ts#, c.name,  d.contents, d.extent_management, e.file_bytes, c.used,

       SUBSTR (c.used / e.file_bytes * 100, 1, 5)

  FROM (SELECT name, ts#, SUM(used) used

          FROM (SELECT a.allocated_space * (SELECT value  -- 查询db_block_size当前值

                                              FROM v$parameter

                                             WHERE name = 'db_block_size') / 1024/ 1024 used,

                        b.ts#, b.name

                  FROM v$filespace_usage a, v$tablespace b

         WHERE a.tablespace_id = b.ts#)

         GROUP BY name, ts#) c,

        dba_tablespaces d,

       (SELECT ts#, SUM(bytes) / 1024/ 1024 file_bytes

          FROM v$datafile

         GROUP BY ts#) e      

 WHERE c.name = d.tablespace_name

   AND e.ts# = c.ts#

 ORDER BY ts#

结果:

ORA-01688:扩展ORACLE表空间操作

(2)现在要扩展表空间:TS_APP_DATA_03,先确定表空间文件:

SELECT FILE#, NAME  FROM V$DATAFILE

结果:

ORA-01688:扩展ORACLE表空间操作

 

(3)更新数据表空间文件大小:

       ALTER DATABASE DATAFILE 9 RESIZE 4G;

说明:此处的 ‘9’是上面查出的FILE# = 9的空间;4G是重新分配的空间大小;

(4)更新结果:

ORA-01688:扩展ORACLE表空间操作

1、查看所有的表空间:SELECT * FROM DBA_TABLESPACES;

2、查看某个用户的默认表空间:SELECT DEFAULT_TABLESPACE,USERNAME FROM DBA_USERS WHERE USERNAME='username';

3、查看表空间剩余容量:SELECT TABLESPACE_NAME,SUM(BYTES) FROM DBA_FREE_SPACE GROUP BY TABLESPACE_NAME;

4、查看表空间数据文件的信息:SELECT * FROM DBA_DATA_FILES;

5、创建表空间:CREATE TABLESPACE ODI  DATAFILE 'D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\ODI.DBF ' SIZE 50M AUTOEXTEND ON NEXT 10M PERMANENT EXTENT MANAGEMENT LOCAL;

完整的建表空间语句:CREATE TABLESPACE tablespace_name DATAFILE 'filename' SIZE size [AUTOEXTEND [ON NEXT size | OFF]] [MAXSIZE size][PERMANENT  | TEMPORARY][EXTENT MANAGEMENT DICTIONARY | LOCAL];

6、重命名表空间:ALTER TABLESPACE oldname RENAME TO newname;

7、设置表空间的读写状态:ALTER TABLESPACE tablespace_name READ ONLY | WRITE;

8、设置表空间的可用状态:ALTER TABLESPACE tablespace_name ONLINE | OFFLINE [NORAML | TEMPORARY | IMMEDIATE];如果是联机状态,那么表空间就可以被用户操作,反之设置成脱机状态,表空间就不是不可用的,脱机状态还包括3种方式。

9、建立大文件表空间:CREATE BIGFILE TABLESPACE tablespace_name DATAFILE 'filename' SIZE size;

10、删除表空间:DROP TABLESPACE tablespace_name [INCLUDING CONTENTS][CASCADE CONSTRAINTS];INCLUDING CONTENTS表示把表空间里的数据文件也删除,CASCADE CONSTRAINTS会把表空间中的完整性也删除。

11、临时表空间一般是指在数据库中存储数据,当内存不够时写入的空间,这个空间并不像一般的表空间,当执行完对数据库的操作后,该空间的内容自动清空。

12、创建临时表空间:CREATE TEMPORARY TABLESPACE tablespace_name TEMPFILE 'filename' SIZE size;

13、设置临时表空间为默认表空间:ALTER DATABASE DEFAULT TEMPORARY TABLESPACE tablespace_name;

14、查询临时表空间:SELECT * FROM DBA_TMP_FILES;

15、创建临时表空间组:CREATE TEMPORARY TABLESPACE tablespace_name TMPFILE 'filename' SIZE size TABLESPACE GROUP group_name;

16、移动临时表空间到表空间组:ALTER TABLESPACE tablespace_name TABLESPACE GROUP group_name;

17、查询临时表空间组:SELECT * FROM DBA_TABLESPACE_GROUPS;

18、删除临时表空间:DROP TABLESPACE tablespace_name INCLUDING CONTENTS AND DATAFILES;

19、删除表空间中的数据文件:ALTER TABLESPACE tablespace_name DROP DATAFILE 'filename';

20、向表空间里增加数据文件:ALTER TABLESPACE tablespace_name ADD DATAFILE 'filename' SIZE size;

21、向表空间里新增数据文件,并且允许数据文件自动增长:ALTER TABLESPACE tablespace_name ADD DATAFILE 'filename' SIZE 50M AUTOEXTEND ON NEXT 5M MAXSIZE 100M;

22、允许已存在的数据文件自动增长:ALTER DATABASE DATAFILE 'filename' AUTOEXTEND ON NEXT 5M MAXSIZE 100M;

23、手工改变已存在数据文件的大小:ALTER DATABASE DATAFILE 'filename' RESIZE 100M;