ITPub博客

首页 > 数据库 > Oracle > ORA-01658 无法为表空间TTS_EX2中的段创建 INITIAL 区

ORA-01658 无法为表空间TTS_EX2中的段创建 INITIAL 区

原创 Oracle 作者:therorawt 时间:2008-06-20 23:12:53 0 删除 编辑

在今天的练习中遇到这个问题,可能有2个原因:
1. 用户默认表空间已满,并且该表空间不支持自动扩展;
2. 用户默认表空间使用有问题;

现把操作步骤帖出来:
sqlplus /nolog
SQL> conn tts_user/tts_user
已连接。

SQL> select * from scott.emp where rownum < 2;
在列 DEPTNO 前截断 (按要求)


EMPNO ENAME JOB MGR HIREDATE SAL COMM
---------- ---------- --------- ---------- ---------- ---------- ----------
7369 SMITH CLERK 7902 17-12月-80 800

[@more@]

SQL> create table emp as select * from scott.emp;
create table emp as select * from scott.emp
*
ERROR 位于第 1 行:
ORA-01658: 无法为表空间TTS_EX2中的段创建 INITIAL 区

SQL> conn / as sysdba

SQL> select username,default_tablespace from dba_users where username = 'TTS_USER'
2 /

USERNAME DEFAULT_TABLESPACE
------------------------------ ------------------------------
TTS_USER TTS_EX2

--查系统表空间情况
SELECT a.tablespace_name "表空间名",total 表空间大小,free 表空间剩余大小,
(total-free) 表空间使用大小,
ROUND((total-free)/total,4)*100 "使用率 %"
FROM (SELECT tablespace_name,SUM(bytes) free FROM DBA_FREE_SPACE
GROUP BY tablespace_name ) a,
(SELECT tablespace_name,SUM(bytes) total FROM DBA_DATA_FILES
GROUP BY tablespace_name) b
WHERE a.tablespace_name=b.tablespace_name and a.tablespace_name = 'TTS_EX2'
/
未选定行

!原来tts_ex2被自己干掉了
修改用户默认表空间
SQL> conn tts_user/tts_user
SQL> alter user tts_user default tablespace tts_ex1
2 /

用户已更改。

SQL> create table emp as select * from scott.emp;

表已创建。

问题得到解决
--the end

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9896745/viewspace-1005927/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 一些有用的东东
请登录后发表评论 登录
全部评论
  • 博文量
    38
  • 访问量
    47454