1)显示当前默认表空间

SQL>select property_name,property_value from database_properties

where property_name in('DEFAULT_PERMANENT_TABLESPACE','DEFAULT_TEMP_TABLESPACE');

默认表空间

2)设置默认表空间

SQL>alter database default tablespace SAMPLE5;

3)设置默认临时表空间:

SQL>alter database default temporary tablespace TEMP3;

4)如果在创建用户时指定了默认表空间为DEFAULT_PERMANENT_TABLESPACE的值,那么在修改数据库的默认表空间后,之前用户的默认表空间也会发生改变。

演示案例,如下

SQL> CREATE USER U1 IDENTIFIED BY U1 DEFAULT TABLESPACE USERS;

SQL> SELECT USERNAME, DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE FROM DBA_USERS

WHERE USERNAME ='U1';

SQL> ALTER DATABASE DEFAULT TABLESPACE SAMPLE5;

修改了默认永久性表空间后,此时查看用户U1的DEFAULT_TABLESPACE值,发现改为SAMPLE5。

SQL> SELECT USERNAME, DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE FROM DBA_USERS WHERE USERNAME ='U1';

5)如果我们在创建用户时没有指定用户表的默认表空间,那么默认也会使用DB的默认表空间

这时候如果我们修改了DB的默认表空间,用户的表空间也会发生改变。

SQL>  ALTER DATABASE  DEFAULT TABLESPACE USERS;

SQL> CREATE USER U2 IDENTIFIED BY U2;

SQL> SELECT USERNAME, DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE FROM DBA_USERS WHERE USERNAME ='U1';

SQL> ALTER DATABASE DEFAULT TABLESPACE SAMPLE5;

SQL> SELECT USERNAME, DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE FROM DBA_USERS WHERE USERNAME ='U1';

6)如果我们在创建用户指定用户的默认表空间是其他的表空间,那么我们修改DB的默认表空间不会影响用户的表空间。

SQL> CREATE USER U3 IDENTIFIED BY U3 DEFAULT TABLESPACE SAMPLE2;

SQL>SELECT USERNAME, DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE FROM DBA_USERS WHERE USERNAME='U3';

SQL> ALTER DATABASE DEFAULT TABLESPACE USERS;

SQL> SELECT USERNAME, DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE FROM DBA_USERS WHERE USERNAME='U3';

7)数据库的默认表空间不能删除,除非将默认表空间指向其他表空间之后才可以删除。

SQL> DROP TABLESPACE USERS;

DROP TABLESPACE USERS

ORA-12919: 不能删除默认永久表空间

8)如果用户的默认表空间指向其他的表空间,比如上述6)中案例,当这个表空间被drop 之后,用户的默认表空间会自动指向DB的默认表空间。

SQL> DROP TABLESPACE SAMPLE2;

上述语句执行完成后,用户的默认表空间会自动指向DB的默认表空间USERS

原文链接:Oracle入门精读46-Oracle默认表空间应用详解(default tablespace)

最后修改:2023 年 10 月 15 日
如果觉得我的文章对你有用,请随意赞赏