java 获取oracle表结构_获取Oracle中所有表的列表?

回答(19)

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

我们可以从以下查询获取所有表格,包括列详细信息:

SELECT * FROM user_tab_columns;

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

使用sqlplus更好地查看

如果您正在使用 sqlplus ,您可能需要首先设置一些参数以便在您的列被破坏时更好地查看(退出 sqlplus 会话后这些变量不应该保留):

set colsep '|'

set linesize 167

set pagesize 30

set pagesize 1000

显示所有表格

然后,您可以使用这样的内容来查看所有表名:

SELECT table_name, owner, tablespace_name FROM all_tables;

显示您自己的表格

正如@Justin Cave所提到的,您可以使用它来显示您拥有的表格:

SELECT table_name FROM user_tables;

不要忘记视图

请记住,某些“表”实际上可能是“视图”,因此您也可以尝试运行以下内容:

SELECT view_name FROM all_views;

结果

这应该产生看起来相当可接受的东西,如:

581fd090-8526-4c09-a6f3-dfadc62e7f6d.png

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

尝试以下数据字典视图 .

tabs

dba_tables

all_tables

user_tables

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

为此存在3个数据

DBA_TABLES describes all relational tables in the database.

SELECT owner, table_name

FROM dba_tables

Description of relational tables accessible to the user

SELECT owner, table_name

FROM all_tables

USER_TABLES 描述了当前用户拥有的关系表 . 此视图不显示 OWNER 列 .

SELECT table_name

FROM user_tables

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

下面是一个注释的SQL查询片段,描述了您可以使用的选项:

-- need to have select catalog role

SELECT * FROM dba_tables;

-- to see tables of your schema

SELECT * FROM user_tables;

-- tables inside your schema and tables of other schema which you possess select grants on

SELECT * FROM all_tables;

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

您可以使用Oracle Data Dictionary获取有关oracle对象的信息 .

您可以通过不同方式获取表的列表:

select *

from dba_tables

或者例如:

select *

from dba_objects

where object_type = 'TABLE'

然后,您可以使用表名获取表列:

select *

from dba_tab_columns

然后,您可以获得依赖项列表(触发器,视图等):

select *

from dba_dependencies

where referenced_type='TABLE' and referenced_name=:t_name

然后你可以得到这个对象的文本来源:

select * from dba_source

如果需要,您可以使用 USER 或 ALL 视图而不是 DBA .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

SELECT owner, table_name

FROM dba_tables

这假设您可以访问 DBA_TABLES 数据字典视图 . 如果您没有这些权限但需要它们,则可以请求DBA明确授予您对该表的权限,或者DBA授予您 SELECT ANY DICTIONARY 权限或 SELECT_CATALOG_ROLE 角色(其中任何一个都允许您查询任何数据)字典表) . 当然,您可能希望排除某些模式,例如 SYS 和 SYSTEM ,这些模式具有您可能不关心的大量Oracle表 .

或者,如果您无权访问 DBA_TABLES ,则可以通过 ALL_TABLES 视图查看您的帐户有权访问的所有表格:

SELECT owner, table_name

FROM all_tables

虽然,这可能是数据库中可用表的子集( ALL_TABLES 显示了您的用户被授予访问权限的所有表的信息) .

如果您只关心您拥有的表,而不是您有权访问的表,则可以使用 USER_TABLES :

SELECT table_name

FROM user_tables

由于 USER_TABLES 仅包含您拥有的表的信息,因此它没有 OWNER 列 - 根据定义,所有者就是您 .

Oracle还有许多遗留数据字典视图 - 例如 TAB , DICT , TABS 和 CAT --可以使用 . 一般情况下,我不建议使用这些遗留视图,除非您绝对需要将脚本反向移植到Oracle 6. Oracle长时间没有更改这些视图,因此它们经常遇到新类型对象的问题 . 例如, TAB 和 CAT 视图都显示有关用户回收站中的表的信息,而 [DBA|ALL|USER]_TABLES 视图都会过滤掉这些表 . CAT 还显示有关具有 TABLE_TYPE "TABLE"的物化视图日志的信息,这不太可能是您真正想要的 . DICT 结合了表和同义词,并没有告诉你谁拥有该对象 .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

select object_name from user_objects where object_type='TABLE';

要么 - - - - - - - - -

select * from tab;

要么 - - - - - - - - -

select table_name from user_tables;

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

我希望获得属于按列id顺序排序的模式表的所有列名称的列表 .

这是我正在使用的查询: -

SELECT COLUMN_NAME

FROM ALL_TAB_COLUMNS

WHERE OWNER = 'schema_owner_username' AND TABLE_NAME='table_name'

ORDER BY COLUMN_ID ASC;

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

有了这些,你可以选择:

SELECT DISTINCT OWNER, OBJECT_NAME

FROM DBA_OBJECTS

WHERE OBJECT_TYPE = 'TABLE' AND OWNER='SOME_SCHEMA_NAME';

SELECT DISTINCT OWNER, OBJECT_NAME

FROM ALL_OBJECTS

WHERE OBJECT_TYPE = 'TABLE' AND OWNER='SOME_SCHEMA_NAME';

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

查询 user_tables 和 dba_tables 无法正常工作 .

这个做了:

select table_name from all_tables

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

更进一步,还有另一个名为cols(all_tab_columns)的视图,可用于确定哪些表包含给定的列名 .

例如:

SELECT table_name, column_name

FROM cols

WHERE table_name LIKE 'EST%'

AND column_name LIKE '%CALLREF%';

查找名称以EST开头的所有表和名称中包含CALLREF的列 .

在计算要加入的列时,这可能会有所帮助,例如,取决于您的表和列命名约定 .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

我没有找到可以指出使用的答案

DBA_ALL_TABLES (ALL_ALL_TABLES/USER_ALL_TABLES)

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

包括观点:

SELECT owner, table_name as table_view

FROM dba_tables

UNION ALL

SELECT owner, view_name as table_view

FROM DBA_VIEWS

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

尝试从user_tables中选择,其中列出了当前用户拥有的表 .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

select * from dba_tables

仅当您登录的用户具有 sysdba 权限时,才会提供所有用户的所有表 .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

以下查询仅列出所需数据,而其他答案给了我额外的数据,这只会让我困惑 .

select table_name from user_tables;

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

简单查询为当前用户选择表:

SELECT table_name FROM user_tables;

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

Oracle数据库使用以下查询显示所有表的名称

SELECT owner, table_name FROM dba_tables;

SELECT owner, table_name FROM all_tables;

SELECT table_name FROM user_tables;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/552523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java后台处理excel_java后台利用Apache poi 生成excel文档提供前台下载示例

之前在项目中会用到在java在后台把数据填入Word文档的模板来提供前台下载,为了自己能随时查看当时的实现方案及方便他人学习我写了这篇博客,访问量已经是我写的博客里第一了。于是乎我在学会用Java在后台利用Apache poi 生成excel文档提供前台下载之后就…

宝塔php漏洞,[安全预警]关于最近宝塔闹得很厉害的PMA漏洞BUG

文章前言在2020年8月23日的下午有个憨憨管理在我群艾特全员 说宝塔爆出漏洞了赶快更新吧!影响机器需同时满足以下所有条件1、软件版本为Linux面板7.4.2 或者Windows面板6.8.02、开放888且未配置http认证,3、安装了phpmyadmin,mysql数据库不受…

求十个学生的平均成绩java,JAVA 声明一个数组,存一个学生的五门成绩。求该学生的总成绩、平均成绩。...

JAVA 声明一个数组,存一个学生的五门成绩。求该学生的总成绩、平均成绩。mip版 关注:116 答案:3 悬赏:30解决时间 2021-01-26 06:39已解决2021-01-25 17:54声明一个数组,存一个学生的五门成绩。求该学生的总成绩、平均成绩。JAVA知识最佳答案2021-01-25 18:12public class S…

php伪静态限制网页播放视频,学习猿地-php伪静态后html不能访问怎么办

php伪静态后html不能访问的解决办法:首先判断文件是否存在;然后设置存在则不rewirte,不存在且符合规则才rewrite;最后修改htaccess文件即可。具体问题:PHP伪静态后不能访问纯html文件.htaccess文件RewriteEngine onRew…

oracle binary_integer pls_integer,oracle中binaryinteger与plsinteger的区别

oracle中binaryinteger与plsinteger的区别 Oracle 中 Binary_Integer 与 Pls_Integer 的区别Binary_Integer 与 Pls_Integer 都是整型类型. Binary_Integer 类型变量值计算是由 Oracle 来执行,不会出现溢出,但是执行速度较慢,因为它是由 Orac…

梁单元分析matlab,[FEM][有限元][编程][Matlab][Code by myself] 2D Timoshenko梁单元

(有空和小伙伴一起写写有限元程序)程序作者 ( Author )JiDong Cui (崔济东)1, XueLong Shen (沈雪龙)21.广州容柏生建筑结构设计事务所;2.华南理工大学建筑设计研究院基本概念 ( Concept )欧拉梁单元基于一定的假设(Kirchhoff假设),在梁的高度远小于其跨…

oracle分组后伪列,Oracle伪列和伪表和分组函数(row_number,Rank)

oracle的伪列以及伪表oracle系统为了实现完整的关系数据库功能,系统专门提供了一组成为伪列(Pseudocolumn)的数据库列,这些列不是在建立对象时由我们完成的,而是在我们建立时由Oracle完成的。Oracle目前有以下伪列:一、伪列&#…

linux运行搜狗拼音,Linux 搜狗输入法的安装(Ubuntu版)

1、首先从搜狗官网下载搜狗输入法Linux版本的安装包2、按ctrl alt T 打开Linux终端3、安装搜狗输入法: sudo dkpg -i xxx.deb, 如果报错,主要是由于两个原因:a、权限不够,可以通过获取root权限,命令‘su’;…

2023年腾讯云轻量应用服务器测评2核2G4M带宽

腾讯云轻量应用服务器测评2核2G4M带宽88元一年,2核CPU、2G内存、3M带宽,腾讯云轻量应用服务器(Tencent Cloud Lighthouse)是一款开箱即用的云服务器产品,面向轻量应用场景,旨在为中小企业和开发者提供便捷高…

linux tcp连接计算机,计算机基础知识——linux socket套接字tcp连接分析

2016.7.4今天晚上对项目顶层文件(daemon)进行了分析,对其中的TCP连接进行具体的代码级分析。1、需求分析首先得知道我们这里为什么要用TCP连接,我们的整个测试系统是由上位机作为客户端,发送测试文件,测试命令给我们测试程序上&am…

定时器驱动数码管c语言程序,74hc595驱动数码管时间程序

74hc595驱动数码管时间程序这里是电路图:下面是51单片机驱动74hc595芯片的程序:#include //包含51单片机的头文件#include#define uint unsigned int#define uchar unsigned char//sbit sin_595 P1^0;//sbit rclk_595 P…

石油大学c语言考试答案,中石油华东2012春《C语言》在线答案

);! X" l4 d0 m5 T0 A 满分:2 分* }4 x X$ a& t, l% i3. 当对两个字符串进行比较时,应该使用的函数是A. strcat, y, Z- S p t! k! GB. strcmp2 } R% s8 P* Z/ yC. strcpy, i$ q. b5 P8 m j v1 k3 H2 W3 mD. strlen* I B S…

c语言中怎么暂停一个一个游戏,求助:最近在linux下用c语言写了一个贪吃蛇程序,有几个问题,第一:贪吃蛇怎么实现暂停,第二:有时候同时输入上下左右中的两个键就会直接游戏结束...

求助:最近在linux下用c语言写了一个贪吃蛇程序,有几个问题,第一:贪吃蛇怎么实现暂停,第二:有时候同时输入上下左右中的两个键就会直接游戏结束/*以下是主要的逻辑代码,还有些.c和.h就没发了*/#i…

android view显示隐藏动画效果,Android 根据手势顶部View自动展示与隐藏效果

首先来看一下效果:大体思路如下:总体布局用了一个自定义的ViewGroup,里面包了两个View(top View,bottomView)我在bottomView里放了ViewPager,里面又有Fragment,Fragment里放的是ListView原理:Vi…

android点击地址调用地图,Android 实现点击按钮 调用手机外部地图导航

//弹出Dialog 选择外部地图private void setMap(){final Dialog dianew AlertDialog.Builder(mContext).create();View viewLayoutInflater.from(mContext).inflate(R.layout.dialog_map, null);dia.show();dia.getWindow().setContentView(view);TextView tv_baidu(TextView) …

android webservices 返回多行多列数据,NoahWeb实现表格多行多列

用NoahWeb的表现层指令可以在动态生成的页面中非常容易的实现多行多列的表格。在正式学习以前我们需要先来了解一下怎么用NoahWeb的表现层来做动态内容显示。在NoahWeb设计器中新建或打开一项目以后,在Macromedia Dreamweaver MX 2004中新建了一个“空页面”&#x…

android程序 美食分享,下厨房Android产品分析

下厨房产品宣传图一、产品概况1、产品简介下厨房菜谱是一款简单实用的美食应用,可以帮助用户寻找想吃的美食,搜索精美食谱,使用购买清单选购食材,与朋友分享自己制作的美食。2、主要竞品美食杰、豆果美食、好豆菜谱、香哈菜谱。二…

html实现图片加载动画效果,HTML5+javascript实现图片加载进度动画效果

在网上找资料的时候,看到网上有图片加载进度的效果,手痒就自己也写了一个。图片加载完后,隐藏loading效果。想看加载效果,请ctrelF5强制刷新或者清理缓存。效果预览:0%代码如下:HTML5javascript实现图片加载…

html5开发app的缺点,全解HTML 5在移动Web应用的优劣势

关于HTML5HTML5具有语义学、本地存储、设备访问、连接性、多媒体、平面和三维效果、性能和集成和CSS3八大技术特征。让Web应用进入无插件时代,在功能和性能上逼近桌面应用。促使应用Web化,实现跨平台。HTML5规范草案将于2012年发布候选推荐版&#xff0c…

html怎么加断点快捷键,HTML添加断点 - osc_vyztkm1b的个人空间 - OSCHINA - 中文开源技术交流社区...

###1.前言 很多时候,页面的dom元素是动态添加的,而我们不知道具体是哪段js代码在操作这个dom元素,所以需要进行断点,对相应的dom元素进行断点监听,这样才能找出相关的js代码。在浏览器的调试工具中,切到ele…