[每日一题] OCP1z0-047 :2013-07-26 alter table set unused之后各种情况处理
有疑问可以去itpub讨论:http://www.itpub.net/thread-1804872-1-1.html
对于alter table setunused的用法,查官方文档:
alter_table::=
SET UNUSED Clause
Specify SET UNUSED to mark one or more columns asunused. Specifying this clause does not actually remove the target columns fromeach row in the table. That is, it does not restore the disk space used bythese columns. Therefore, the response time is faster than when you execute theDROP clause.
You can view all tables with columns marked UNUSED in the data dictionary views USER_UNUSED_COL_TABS, DBA_UNUSED_COL_TABS, and ALL_UNUSED_COL_TABS.
Unused columns are treated as if they were dropped, even though theircolumn data remains in the table rows. After a column has been marked UNUSED, you have no access to that column. A SELECT * query will not retrieve data from unusedcolumns. In addition, the names and types of columns marked UNUSED will not be displayed during a DESCRIBE, and you can add to the table a new column with the same name as an unusedcolumn.
对上面的题,先做实验,看测试结果,一一验证:
1、在gyj用户下创建一个表:
gyj@OCM> create table emp as select employee_id,first_name,manager_idfrom hr.employees;
Table created.
2、 创建一个公共的同义词e
gyj@OCM> create public synonym e for emp;
Synonym created.
gyj@OCM> select * from e;
EMPLOYEE_ID FIRST_NAME MANAGER_ID
----------- -------------------- ----------
198 Donald 124
199 Douglas 124
省略结果。。。。。
3、创建一个私有的同义词m
gyj@OCM> create synonym m foremp;
Synonym created.
gyj@OCM> select * from m;
EMPLOYEE_ID FIRST_NAME MANAGER_ID
----------- -------------------- ----------
198 Donald 124
199 Douglas 124
省略结果。。。。。
4、在字段manager_id列上建一个条件check约束
gyj@OCM> alter table emp add(constraint c_emp_manageridcheck(manager_id>=100));
Table altered.
gyj@OCM> select CONSTRAINT_NAME from user_constraints wheretable_name='EMP';
CONSTRAINT_NAME
------------------------------
C_EMP_MANAGERID
gyj@OCM> insert into emp values(500,'guoyJoe',99);
insert into emp values(500,'guoyJoe',99)
*
ERROR at line 1:
ORA-02290: check constraint (GYJ.C_EMP_MANAGERID) violated
报错是说明不满足约束,说明约束起作用了
5、创建一个视图v_emp
gyj@OCM> create view v_emp as select * from emp;
View created.
gyj@OCM> select * from v_emp;
EMPLOYEE_ID FIRST_NAME MANAGER_ID
----------- -------------------- ----------
198 Donald 124
199 Douglas 124
省略结果。。。
6、在列manager_id上创建一个索引
gyj@OCM> create index idx_id on emp(manager_id);
Index created.
gyj@OCM> select index_name from user_indexes where table_name='EMP';
INDEX_NAME
------------------------------
IDX_ID
好,我们按上面的题意,开始做alter table set unused操作:
gyj@OCM> altertable emp set unused ( manager_id);
Table altered.
同义词在数据字典中还能用,无需重建,所以答案A错
gyj@OCM> select OBJECT_NAME FROM user_objects where object_type='SYNONYM'AND OBJECT_NAME IN('M','E');
OBJECT_NAME
--------------------------------------------------
M
gyj@OCM> select * from e;
EMPLOYEE_ID FIRST_NAME MANAGER_ID
----------- -------------------- ----------
198 Donald 124
199 Douglas 124
省略结果。。。。。
gyj@OCM> select * from m;
EMPLOYEE_ID FIRST_NAME MANAGER_ID
----------- -------------------- ----------
198 Donald 124
199 Douglas 124
省略结果。。。。。
数据字典中manager_id列的约束被删除了。所以答案B对
gyj@OCM> select CONSTRAINT_NAME from user_constraints wheretable_name='EMP';
no rows selected
去查视图,报错如下:
gyj@OCM> select * from v_emp;
select * from v_emp
*
ERROR at line 1:
ORA-04063: view "GYJ.V_EMP" has errors
此时视图不能用了。。。答案C的意思必须删除这个视图再重建这个视图才行,一定要这做吗?我不重建视图,在视图所在表中重新添加manager_id这一列,看看视图能不能用:
gyj@OCM> alter table emp add( MANAGER_ID NUMBER(6));
Table altered.
gyj@OCM> select * from v_emp;
EMPLOYEE_ID FIRST_NAME MANAGER_ID
----------- -------------------- ----------
198 Donald
199 Douglas
省略结果。。。
说明视图无须删除和重建,只在表中添加刚刚被unused的这列就可以了,所以答案C错的
数据字典中manager_id列的索引被删除了。所以答案D错
gyj@OCM> select index_name fromuser_indexes where table_name='EMP';
no rows selected
正确答案是:B
[每日一题] OCP1z0-047 :2013-07-26 alter table set unused之后各种情况处理的更多相关文章
- [Buzz.Today]2013.07.26
# OpenFab 3D printing hardware is rapidly scaling up to output continuous mixtures of multiple mater ...
- 老男孩IT教育-每日一题汇总
老男孩IT教育-每日一题汇总 第几天 第几周 日期 快速访问链接 第123天 第二十五周 2017年8月25日 出现Swap file….already exists以下错误如何解决? 第122天 2 ...
- PL/SQL Challenge 每日一题:2014-3-14 11gR2中带RELIES_ON子句的RESULT_CACHE函数
PL/SQL Challenge 每日一题:2014-3-14 11gR2中带RELIES_ON子句的RESULT_CACHE函数 最先答对且答案未经编辑的puber将获得纪念章一枚(答案不可编辑但可 ...
- 【JavaScript】【dp】Leetcode每日一题-解码方法
[JavaScript]Leetcode每日一题-解码方法 [题目描述] 一条包含字母 A-Z 的消息通过以下映射进行了 编码 : 'A' -> 1 'B' -> 2 ... 'Z' -& ...
- 【python】Leetcode每日一题-前缀树(Trie)
[python]Leetcode每日一题-前缀树(Trie) [题目描述] Trie(发音类似 "try")或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的 ...
- LeetCode 每日一题「判定字符是否唯一」
我是陈皮,一个在互联网 Coding 的 ITer,微信搜索「陈皮的JavaLib」第一时间阅读最新文章,回复[资料],即可获得我精心整理的技术资料,电子书籍,一线大厂面试资料和优秀简历模板. 题目 ...
- 【Java每日一题】20170106
20170105问题解析请点击今日问题下方的"[Java每日一题]20170106"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...
- 【Java每日一题】20170105
20170104问题解析请点击今日问题下方的"[Java每日一题]20170105"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...
- 【Java每日一题】20170104
20170103问题解析请点击今日问题下方的"[Java每日一题]20170104"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...
随机推荐
- TCP通信中的大文件传送
TCP通信中的大文件传送 源码 (为节省空间,不包含通信框架源码,通信框架源码请另行下载) 文件传送在TCP通信中是经常用到的,本文针对文件传送进行探讨 经过测试,可以发送比较大的文件,比如1个G ...
- 解决OUTLOOK 533错误问题
OutLook中“553 sorry, that domain isn‘t in my list of allowed rcpthosts (#5.7.1)”,无法发送邮件错误,解决方法 最近我在给徐 ...
- Entity Framework 处理并发
Entity Framework 处理并发 在以前的两个教程你对关联数据进行了操作.本教程展示如何处理并发性.您将创建工作与各Department实体的 web 页和页,编辑和删除Department ...
- Asp.Net MVC5入门学习系列③
原文:Asp.Net MVC5入门学习系列③ 添加一个视图(View) 接着上篇的入门系列,上面解说添加一个简单Controller(控制器),这里我们简单的在来添加一个View(视图)来展示我们Co ...
- C语言得到当前系统时间
void getTime(){ //获取当前系统时间 time_t tTime;//距离1900年1月1日的秒数 char str[80]; struct tm* stTim;//时间结构 time( ...
- 【iOS】Xib的使用与File'Owner总结
一.XIB的适用范围 xib(也叫Nib)与storyboard一样是用来描写叙述界面的. storyboard描写叙述的是比較大型的,大范围.适合描写叙述界面跳转等. 二.XIB的使用 Xib是小范 ...
- C#yield return和yield break
C#yield return和yield break 晚上好,各位.今天结合书中所讲和MSDN所查,聊下yield关键字,它是我们简化迭代器的关键. 如果你在语句中使用了yield关键字,则意味着它在 ...
- 如果在VMware上免费下载驱动
1.在不登录,或者没有账号的情况下,进入VMare的驱动下载界面,可以发现有一个大大的Download按钮. 2.点这个按钮,会提示登录. 3.注册账号登录后,回到驱动下载界面,会发现Download ...
- 《C语言及程序设计初步》网络课程主页
题记 CSDN要开在线教育频道,向我发出邀请,看能否开些课程. 我近日一直在关注着翻转课堂,试图在传统课堂中引入新的元素,这须要资源建设的积累.没有时间表的工作,非常难把握. 为CSDN做在线课程,为 ...
- POJ 3380 最大流
Paratroopers Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit ...