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

 更新时间:2025年08月02日 08:44:58   作者:左眼看成爱  
使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.substr函数准备,建议优先使用USER_TAB_COLUMNS以减少混淆,参考Oracle官方文档ALL_TAB_COLS

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Oracle和Mysql的主要区别

    Oracle和Mysql的主要区别

    Oracle 和 MySQL 都是常见的关系型数据库管理系统(RDBMS),但它们在架构、功能、性能、使用场景等方面有很大区别,下面给大家分享Oracle和Mysql的区别,感兴趣的朋友一起看看吧
    2025-05-05
  • Oracle使用EMCC监控当前所有数据库的流程步骤

    Oracle使用EMCC监控当前所有数据库的流程步骤

    EMCC,全称Oracle Enterprise Manager Cloud Control,是Oracle提供的一套集中化监控工具,可以对数据库、操作系统、中间件等进行监控,本文小编给大家介绍了Oracle使用EMCC监控当前所有数据库的流程步骤,需要的朋友可以参考下
    2024-09-09
  • Oracle自定义脱敏函数的代码详解

    Oracle自定义脱敏函数的代码详解

    这篇文章主要介绍了Oracle自定义脱敏函数的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-07-07
  • Oracle数据库字符集及修改方式详解

    Oracle数据库字符集及修改方式详解

    Oracle语言环境的描述包括三部分:language、territory、characterset(语言、地域、字符集),这篇文章主要介绍了Oracle数据库字符集概述及修改方式,需要的朋友可以参考下
    2023-08-08
  • ORA-00349|激活 ADG 备库时遇到的问题及处理方法

    ORA-00349|激活 ADG 备库时遇到的问题及处理方法

    这篇文章主要介绍了ORA-00349|激活 ADG 备库时遇到的问题及处理方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • 一文详解Oracle存储过程

    一文详解Oracle存储过程

    Oracle存储过程是Oracle数据库中的一种数据处理对象,它可以在数据库中定义一组预定义的SQL语句,用于完成特定的数据库操作,本文将通过代码示例详细介绍了Oracle存储过程,需要的朋友可以参考下
    2023-05-05
  • oracle Dbeaver存储过程语法详解

    oracle Dbeaver存储过程语法详解

    这篇文章主要介绍了oracle Dbeaver存储过程语法详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-10-10
  • Oracle 12CR2查询转换教程之cursor-duration临时表详解

    Oracle 12CR2查询转换教程之cursor-duration临时表详解

    这篇文章主要给大家介绍了关于Oracle 12CR2查询转换教程之cursor-duration临时表的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Windows10系统中Oracle完全卸载正确步骤

    Windows10系统中Oracle完全卸载正确步骤

    自己刚到公司就是熟悉数据库的安装卸载,所以分享一下学到的,下面这篇文章主要给大家介绍了关于Windows10系统中Oracle完全卸载正确步骤的相关资料,文章通过图文介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • Oracle如何直接运行OS命令(上)

    Oracle如何直接运行OS命令(上)

    Oracle如何直接运行OS命令(上)...
    2007-03-03

最新评论