开发者

Oracle查询表结构建表语句索引等方式

目录
  • oracle查询表结构建表语句索引
    • 1.用“USER_TAB_COLUMNS”查询表结构
    • 2.用“all_tab_COLUMNS”查询表结编程客栈
  • 总结

    Oracle查询表结构建表语句索引

    --表的备注说明: user_tab_comments
    --栏位的备注说明: user_col_comments
    --系统视图 all_tab_cols  fobdBALL_TAB_COLS描述了当前用户可访问的表,视图和群集的列。要收集此视图的统计信息,请使用ANALYandroidZESQL语句或DBMS_STATS程序包。
    --该视图与“ ALL_TAB_COLUMNS”不同之处在于,未过滤掉隐藏的列。
    --使用时尽量使用USER_TAB_COLUMNS,以避免获取到oracle自行添加的隐藏字段。
    
    --ORACLE 查询表结构
    SELECT table_name, column_name, data_type,DATA_LENGTH,COLUMN_ID FROM USER_TAB_COLUMNS WHERE table_name =upper('b_notice')
    select * from user_tab_columns where table_name='B_NOTICE'
    SELECT * FROM all_tab_cols WHERE table_name =upper('b_notice')
    
    --查看建表语句
    select dbms_metadata.get_ddl('TABLE','B_NOTICE') from dual;
    
    --查看oracle单个数据表包含的索引
    select * from user_indexes where table_name=u编程pper('B_NOTICE');
    
    --查看哪些表哪些字段包含指定类型
    SELECT table_name, column_name, data_type,DATA_LENGTH,COLUMN_ID FROM all_tab_cols WHERE data_type 编程=upper('NVARCHAR2')

    同样的表名:F_Flow_Step   

    1.用“USER_TAB_COLUMNS”查询表结构

    SELECT table_name, column_name, data_type,DATA_LENGTH,COLUMN_ID FROM USER_TAB_COLUMNS WHERE table_name =upper('F_Flow_Step') 

    Oracle查询表结构建表语句索引等方式

    2.用“all_tab_COLUMNS”查询表结构

    SELECT table_name, column_name, data_type,DATA_LENGTH,COLUMN_ID FROM ALL_TAB_COLUMNS WHERE table_name =upper('F_Flow_Step')

    Oracle查询表结构建表语句索引等方式

    会发现“all_tab_COLUMNS” 比“USER_TAB_COLUMNS”多了很多同名字段。

    比如:

    USER_TAB_COLUMNS 里的LISTUSER字段,类型为CLOB 但是在all_tab_COLUMNS查询下出现了两个同名字段,除了CLOB类型的还有一个长度为2000的varchar2的Listuser,说明,这个字段也许是为dbms_lob.substr(clob_column)这个oracle内置的函数截取CLOB同名字段varchar2值所准备的用途(本人猜测)。

    所以,建议查询表结构的时候使用USER_TAB_COLUMNS,避免查询出系统隐藏字段。

    参考oracle官方资料:ALL_TAB_COLS

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。

    0

    上一篇:

    下一篇:

    精彩评论

    暂无评论...
    验证码 换一张
    取 消

    最新数据库

    数据库排行榜