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