set unused column和视图,约束,同义词和索引的关系
2014-03-19 20:05
295 查看
当使用alter table set unused column语法之后,会对其相关联的视图,约束,同义词和索引有什么作用么?
答案是:
视图和同义词会失效,其中同义词再次引用即可重新编译,但是视图重新编译会报错;
约束和索引会被自动删除。
实验:
SQL> create table test as select * from dba_objects;
Table created.
SQL> create view testview as select * from test;
View created.
SQL> alter table test add constraint testc check(object_id<999999);
Table altered.
SQL> create index testidx on test(object_id);
Index created.
SQL> create synonym testsyn for test;
Synonym created.
SQL> select CONSTRAINT_NAME,status from user_constraints
2 where CONSTRAINT_NAME in ('TESTC');
CONSTRAINT_NAME STATUS
------------------------------ --------
TESTC ENABLED
SQL> select OBJECT_NAME,status from user_objects
2 where OBJECT_NAME in ('TESTVIEW','TESTIDX','TESTSYN');
OBJECT_NAME STATUS
------------------------------ -------
TESTIDX VALID
TESTSYN VALID
TESTVIEW VALID
SQL> alter table test set unused (object_id);
Table altered.
SQL> select CONSTRAINT_NAME,status from user_constraints
2 where CONSTRAINT_NAME in ('TESTC');
no rows selected
SQL> select OBJECT_NAME,status from user_objects
2 where OBJECT_NAME in ('TESTVIEW','TESTIDX','TESTSYN');
OBJECT_NAME STATUS
------------------------------ -------
TESTSYN INVALID
TESTVIEW INVALID
SQL> select count(*) from TESTSYN;
COUNT(*)
----------
10069
SQL> select count(*) from TESTVIEW;
select count(*) from TESTVIEW
*
ERROR at line 1:
ORA-04063: view "HAO.TESTVIEW" has errors
答案是:
视图和同义词会失效,其中同义词再次引用即可重新编译,但是视图重新编译会报错;
约束和索引会被自动删除。
实验:
SQL> create table test as select * from dba_objects;
Table created.
SQL> create view testview as select * from test;
View created.
SQL> alter table test add constraint testc check(object_id<999999);
Table altered.
SQL> create index testidx on test(object_id);
Index created.
SQL> create synonym testsyn for test;
Synonym created.
SQL> select CONSTRAINT_NAME,status from user_constraints
2 where CONSTRAINT_NAME in ('TESTC');
CONSTRAINT_NAME STATUS
------------------------------ --------
TESTC ENABLED
SQL> select OBJECT_NAME,status from user_objects
2 where OBJECT_NAME in ('TESTVIEW','TESTIDX','TESTSYN');
OBJECT_NAME STATUS
------------------------------ -------
TESTIDX VALID
TESTSYN VALID
TESTVIEW VALID
SQL> alter table test set unused (object_id);
Table altered.
SQL> select CONSTRAINT_NAME,status from user_constraints
2 where CONSTRAINT_NAME in ('TESTC');
no rows selected
SQL> select OBJECT_NAME,status from user_objects
2 where OBJECT_NAME in ('TESTVIEW','TESTIDX','TESTSYN');
OBJECT_NAME STATUS
------------------------------ -------
TESTSYN INVALID
TESTVIEW INVALID
SQL> select count(*) from TESTSYN;
COUNT(*)
----------
10069
SQL> select count(*) from TESTVIEW;
select count(*) from TESTVIEW
*
ERROR at line 1:
ORA-04063: view "HAO.TESTVIEW" has errors
相关文章推荐
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- 对SET UNUSED Clause本质的理解(以及 SET UNUSED Clause和 DROP(column) clause的关系 )
- Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间
- oracle表空间,角色,权限,表,索引,序列号,视图,同义词,约束条件,存储函数和过程,常用数据字典,基本数据字典信息,查看VGA信息,维护表空间,创建表空间等信息
- Oracle组函数、多表查询、集合运算、数据库对象(序列、视图、约束、索引、同义词)等
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)自_baidu
- Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- 【转】查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- Oracle创建表、约束、视图、索引、序列、同义词、表空间
- 查看Oracle当前用户下的信息(用户,表视图,索引,表空间,同义词,存储过程函数,约束条件)
- Oracle组函数、多表查询、集合运算、数据库对象(序列、视图、约束、索引、同义词)等
- Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间
- Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间
- Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间