如何查询Oracle数据库以显示Oracle数据库中所有表的名称?
当前回答
我找不到一个有用的答案
DBA_ALL_TABLES (ALL_ALL_TABLES/USER_ALL_TABLES)
所以决定加上我的版本。 这个视图实际上返回比DBA_TABLES更多的数据,因为它也返回对象表(http://docs.oracle.com/cd/E11882_01/server.112/e40402/statviews_1003.htm)。
其他回答
select * from dba_tables
仅当您登录的用户具有sysdba权限时,才提供所有用户的所有表。
有了这些,你可以选择:
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';
为了更好地使用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 table_name FROM user_tables;
执行以下命令:
显示Oracle数据库中的所有表
SELECT table_name FROM dba_tables;
显示当前用户拥有的表
SELECT table_name FROM user_tables;
显示当前用户可以访问的表
sql> SELECT table_name FROM all_tables
推荐文章
- 如何在SQL中选择表的最后一条记录?
- SQL在Oracle中连接多行列值的查询
- 在单个查询中计算空值和非空值
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- SQL to LINQ工具
- 如何从一个查询插入多行使用雄辩/流利
- 如何连接列在Postgres选择?
- 有人可以对SQL查询进行版权保护吗?
- 如何知道MySQL表最近一次更新?
- 如何转储一些SQLite3表的数据?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?
- 在MySQL中的一个查询中更新多个具有不同值的行
- 在SQL中更新多个列
- 如何删除表中特定列的第一个字符?
- MySQL OR与IN性能