当前位置: 代码网 > it编程>数据库>Oracle > Oracle查询表结构建表语句索引等方式

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

2025年08月02日 Oracle 我要评论
oracle查询表结构建表语句索引--表的备注说明: user_tab_comments--栏位的备注说明: user_col_comments--系统视图 all_tab_cols all_tab

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官方资料:all_tab_cols

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com