有疑问可以去itpub讨论:http://www.itpub.net/thread-1804872-1-1.html

对于alter table setunused的用法,查官方文档:

alter_table::=

column_clauses::=

drop_column_clause ::=

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之后各种情况处理的更多相关文章

  1. [Buzz.Today]2013.07.26

    # OpenFab 3D printing hardware is rapidly scaling up to output continuous mixtures of multiple mater ...

  2. 老男孩IT教育-每日一题汇总

    老男孩IT教育-每日一题汇总 第几天 第几周 日期 快速访问链接 第123天 第二十五周 2017年8月25日 出现Swap file….already exists以下错误如何解决? 第122天 2 ...

  3. PL/SQL Challenge 每日一题:2014-3-14 11gR2中带RELIES_ON子句的RESULT_CACHE函数

    PL/SQL Challenge 每日一题:2014-3-14 11gR2中带RELIES_ON子句的RESULT_CACHE函数 最先答对且答案未经编辑的puber将获得纪念章一枚(答案不可编辑但可 ...

  4. 【JavaScript】【dp】Leetcode每日一题-解码方法

    [JavaScript]Leetcode每日一题-解码方法 [题目描述] 一条包含字母 A-Z 的消息通过以下映射进行了 编码 : 'A' -> 1 'B' -> 2 ... 'Z' -& ...

  5. 【python】Leetcode每日一题-前缀树(Trie)

    [python]Leetcode每日一题-前缀树(Trie) [题目描述] Trie(发音类似 "try")或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的 ...

  6. LeetCode 每日一题「判定字符是否唯一」

    我是陈皮,一个在互联网 Coding 的 ITer,微信搜索「陈皮的JavaLib」第一时间阅读最新文章,回复[资料],即可获得我精心整理的技术资料,电子书籍,一线大厂面试资料和优秀简历模板. 题目 ...

  7. 【Java每日一题】20170106

    20170105问题解析请点击今日问题下方的"[Java每日一题]20170106"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...

  8. 【Java每日一题】20170105

    20170104问题解析请点击今日问题下方的"[Java每日一题]20170105"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...

  9. 【Java每日一题】20170104

    20170103问题解析请点击今日问题下方的"[Java每日一题]20170104"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...

随机推荐

  1. webBrowser.execWB的完整说明

    原文:webBrowser.execWB的完整说明 在不是js打开的页面上按window.close(), 会有提示框,很烦,现在可以不用了,没有提示框直接关闭窗口.试试下面代码: <objec ...

  2. 概率图形模型(PGM)学习笔记(一)动机和概述

    在本文中,基于Daphne Koller完成课程. PDM(ProbabilisticGraphiccal Models) 称为概率图模型. 以下分别说明3个词相应的意义. 概率 -给出了不确定性的明 ...

  3. C#-面向对象的多态思想 ---ShinePans

    总结: 多态是面向对象的核心.---------能够理解为一个方法,多种实现, 在这里能够用虚方法,抽象类,接口能够实现多态 1.首先利用接口来实现多态: 接口相当于"功能,"接口 ...

  4. ultraEdit-32 PHP/HTML智能提示

    原文 ultraEdit-32 PHP/HTML智能提示 高级–>配置–>编辑器–>自动完成–>勾选自动显示……选项,在下面输入框中输入你要求输出多个字符才出现提示,比如 ec ...

  5. Springmvc 配置json输出的几种方式

    Spring MVC 3.0 返回JSON数据的几种方法: 1. 直接 PrintWriter 输出 2. 使用 JSP 视图 3. 使用Spring内置的支持 // Spring MVC 配置 &l ...

  6. CSS3可按进度变色的进度条

    原文:CSS3可按进度变色的进度条 今天是周末,看到一款利用CSS3实现的进度条应用,觉得非常棒,就将它分享给大家,并且将这款CSS3进度条的实现过程大致整理了一下,实现的关键是根据当前的进度需要能改 ...

  7. thrift js javascript C# Csharp webservice

    http://www.cnblogs.com/xxxteam/archive/2013/04/15/3023159.html 利用thrift实现js与C#通讯的例子 关键字:thrift js ja ...

  8. Light OJ 1316 A Wedding Party 最短路+状态压缩DP

    题目来源:Light OJ 1316 1316 - A Wedding Party 题意:和HDU 4284 差点儿相同 有一些商店 从起点到终点在走过尽量多商店的情况下求最短路 思路:首先预处理每两 ...

  9. Math.Round函数四舍五入

    Math.Round函数四舍五入的问题   今天客户跑过来跟我说,我们程序里面计算的价格不对,我检查了一下,发现价格是经过折算后的价格,结果是可能小数位较多,而单据上只能打印两位价格,所以就对价格调用 ...

  10. 如何查找Linux的函数定义的位置?

    网上的许多站点提供这样的服务,如下面这个: http://lxr.free-electrons.com/ident?v=3.10 Linux的错误返回值:3.10版本 Linux/include/ua ...