Oracle查询表结构建表语句索引等
--表的备注说明: user_tab_comments --栏位的备注说明: user_col_comments --系统视图 all_tab_cols ALL_TAB_COLS描述了当前用户可访问的表,视图和群集的列。要收集此视图的统计信息,请使用ANALYZESQL语句或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=upper('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')
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')
会发现“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官方资料:https://docs.oracle.com/cd/B19306_01/server.102/b14237/statviews_2093.htm
本文来自博客园,作者:IT情深,转载请注明原文链接:https://www.cnblogs.com/wh445306/p/16751914.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?