zoukankan      html  css  js  c++  java
  • oracle 12c中的隐含列


     
     

    Invisible Columns

    使用select * from ,desc 等看不到该列,

    DROP TABLE tab1 PURGE;
    
    CREATE TABLE tab1 (
      id          NUMBER,
      description VARCHAR2(50) INVISIBLE
    );
    
    DESC tab1;
     Name                                      Null?    Type
     ----------------------------------------- -------- ----------------------------
     ID                                                 NUMBER
    
    SQL>
    
    INSERT INTO tab1 VALUES (1);
    COMMIT;
    
    SELECT * FROM tab1;
    
            ID
    ----------
             1
    
    SQL>

    在明确的指定它的名字进行查询的时候仍然是可用的

    INSERT INTO tab1 (id, description) VALUES (2, 'TWO');
    COMMIT;
    
    SELECT id, description
    FROM   tab1;
    
            ID DESCRIPTION
    ---------- --------------------------------------------------
             1
             2 TWO
    
    SQL>

    下面关于隐含列的几项内容

    • 虚拟列可以设成invisible
    • 一个表可以对隐含列就行分区,
    • 外部表,表簇,临时表中不能包含隐含列
    • 用户自定义的类型不能包含隐含属性
    • You can not make system generated hidden columns visible.

    Invisible Columns and Column Ordering

    隐含列不分配列的顺序(colum_id),如果一个可见的列设为不可见,那么这个列将放到最后一列

    DROP TABLE tab1 PURGE;
    
    CREATE TABLE tab1 (
      a NUMBER,
      b NUMBER,
      c NUMBER INVISIBLE
    );
    
    COLUMN column_name FORMAT A15
    
    SELECT column_id,
           column_name,
           hidden_column
    FROM   user_tab_cols
    WHERE  table_name = 'TAB1'
    ORDER BY column_id;
    
     COLUMN_ID COLUMN_NAME     HID
    ---------- --------------- ---
             1 A               NO
             2 B               NO
               C               YES
    
    SQL> 
    
    ALTER TABLE tab1 MODIFY b INVISIBLE;
    ALTER TABLE tab1 MODIFY c VISIBLE;
    
    SELECT column_id,
           column_name,
           hidden_column
    FROM   user_tab_cols
    WHERE  table_name = 'TAB1'
    ORDER BY column_id;
    
     COLUMN_ID COLUMN_NAME     HID
    ---------- --------------- ---
             1 A               NO
             2 C               NO
               B               YES
    
    SQL>
    
    ALTER TABLE tab1 MODIFY b VISIBLE;
    
    SELECT column_id,
           column_name,
           hidden_column
    FROM   user_tab_cols
    WHERE  table_name = 'TAB1'
    ORDER BY column_id;
    
     COLUMN_ID COLUMN_NAME     HID
    ---------- --------------- ---
             1 A               NO
             2 C               NO
             3 B               NO
    
    SQL>

    强制类型Invisible Columns

    隐含列的强制/可选等属性仍然是有效的,如下例:(隐含列的not null属性仍然是生效的)

    DROP TABLE tab1 PURGE;
    
    CREATE TABLE tab1 (
      id          NUMBER NOT NULL,
      description VARCHAR2(50) NOT NULL,
      created_date DATE INVISIBLE NOT NULL
    );
    
    COLUMN column_name FORMAT A20
    
    SELECT column_id,
           column_name,
           nullable,
           hidden_column
    FROM   user_tab_cols
    WHERE  table_name = 'TAB1'
    ORDER BY column_id;
    
     COLUMN_ID COLUMN_NAME          N HID
    ---------- -------------------- - ---
             1 ID                   N NO
             2 DESCRIPTION          N NO
               CREATED_DATE         N YES
    
    SQL>
    
    INSERT INTO tab1 VALUES (1, 'ONE');
    *
    ERROR at line 1:
    ORA-01400: cannot insert NULL into ("TEST"."TAB1"."CREATED_DATE")
    
    SQL>
    
    ALTER TABLE tab1 MODIFY created_date NULL;
    INSERT INTO tab1 VALUES (1, 'ONE');
    
    1 row created.
    
    SQL>
  • 相关阅读:
    javaScript删除对象、数组中的null、undefined、空对象、空数组方法
    js数组方法 改变原数组和不改变原数组的方法整理
    js时间戳与日期格式的相互转换
    [原创]jquery更换头像
    css样式大全(copy自一个大佬的博文)
    【原创】实现点击按钮更换表格皮肤效果
    Cookie和Seesion
    常用正则表达式
    【原创】javaWeb完成增删查改功能
    javaWeb完成注册功能
  • 原文地址:https://www.cnblogs.com/haoxiaoyu/p/3943918.html
Copyright © 2011-2022 走看看