如何查询Oracle数据库以显示Oracle数据库中所有表的名称?
当前回答
select * from dba_tables
仅当您登录的用户具有sysdba权限时,才提供所有用户的所有表。
其他回答
更进一步,还有一个名为cols (all_tab_columns)的视图,可用于确定哪些表包含给定的列名。
例如:
SELECT table_name, column_name
FROM cols
WHERE table_name LIKE 'EST%'
AND column_name LIKE '%CALLREF%';
查找名称以EST开头的所有表以及名称中任何位置包含CALLREF的列。
例如,根据表和列的命名约定,这可以帮助确定要连接哪些列。
为了更好地使用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;
结果
这应该会产生一些看起来相当可以接受的东西,比如:
当前用户登录模式中的表
select * from tabs;
select * from dba_tables
仅当您登录的用户具有sysdba权限时,才提供所有用户的所有表。
select object_name from user_objects where object_type='TABLE';
---------------- 或 ------------------
select * from tab;
---------------- 或 ------------------
select table_name from user_tables;
推荐文章
- NVL和Coalesce之间的Oracle差异
- 在SQL server查询中将NULL替换为0
- 在SQL中修改表的模式名
- 如何在SQL Server 2005的一条语句中更新两个表?
- 如何创建临时表与SELECT * INTO tempTable从CTE查询
- 用于查找计数为>的记录的SQL查询
- “从Table1左连接Table2”和“从Table2右连接Table1”可以互换吗?
- 在SQL Server的选择语句中使用带TOP的变量,而不是动态的
- 自然连接和内部连接的区别
- MySQL现在()+1天
- 在SQL中转换月号到月名函数
- 不可重复读和幻影读的区别是什么?
- 改变一个varchar列的最大长度?
- 外键约束:何时使用ON UPDATE和ON DELETE
- ORA-00054:资源繁忙,指定NOWAIT或超时获取