`
- 浏览:
41279 次
- 性别:
- 来自:
北京
-
oracle查询所有用户表的表名、主键名称、索引、外键
oracle查询所有用户表的表名、主键名称、索引、外键等(转)
注:所要查询的表名大写.例如:'USER'
1、查找表的所有索引(包括索引名,类型,构成列):
select t.*,i.index_type from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name and t.table_name = 要查询的表
2、查找表的主键(包括名称,构成列):
select cu.* from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'P' and au.table_name = 要查询的表
3、查找表的唯一性约束(包括名称,构成列):
select column_name from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'U' and au.table_name = 要查询的表
4、查找表的外键(包括名称,引用表的表名和对应的键名,下面是分成多步查询):
select * from user_constraints c where c.constraint_type = 'R' and c.table_name = 要查询的表
查询外键约束的列名:
select * from user_cons_columns cl where cl.constraint_name = 外键名称
查询引用表的键的列名:
select * from user_cons_columns cl where cl.constraint_name = 外键引用表的键名
5、查询表的所有列及其属性
select t.*,c.COMMENTS from user_tab_columns t,user_col_comments c where t.table_name = c.table_name and t.column_name = c.column_name and t.table_name = 表名
6、Oracle中每个用户表的表名和行数
select table_name,num_rows from user_tables;
7、Oracle查询用户表空间:select * from user_all_tables
8、Oracle查询所有函数和储存过程:select * from user_source
9、Oracle查询所有用户:
select * from all_users;
select * from dba_users
10、Oracle查看当前用户连接:select * from v$Session
11、Oracle查看当前用户权限:select * from session_privs
12、Oracle查看用户表空间使用情况:
select a.file_id "FileNo",a.tablespace_name
"Tablespace_name",
a.bytes "Bytes",a.bytes-sum(nvl(b.bytes,0)) "Used",
sum(nvl(b.bytes,0)) "Free",
sum(nvl(b.bytes,0))/a.bytes*100 "%free"
from dba_data_files a, dba_free_space b
where a.file_id=b.file_id(+)
group by a.tablespace_name ,
a.file_id,a.bytes order by a.tablespace_name;
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
根据提供的标题、描述以及部分代码内容,我们可以了解到这篇文章主要探讨的是如何在Oracle数据库中查询所有用户表的相关信息,包括表名、主键名称、索引、外键等元数据信息。接下来,我们将对这些知识点进行详细的...
另附以下功能 * 生成目录树 * 生成迁移脚本 * 查找所有System.out,.err * 批量替换多关键字 详情见 http://blog.csdn.net/amosryan/article/details/6684465
在Oracle数据库管理系统中,表空间(Tablespace)是存储数据对象(如表、索引、视图等)的逻辑单位。创建表空间是数据库管理的基础,因为它为数据提供了存储空间。下面将详细介绍如何创建表空间以及如何在Oracle中...
这个过程通常涉及删除数据库中的所有表、存储过程、主键、外键以及索引等对象。下面我们将详细探讨这些概念及其在数据库中的作用,以及如何安全有效地执行删除操作。 首先,让我们逐一了解这些数据库元素: 1. 表...
此查询将返回特定表的所有外键信息,包括外键名称、关联的列名以及关联的外键约束名称。 #### 4. 查询关联表的信息 为了进一步获取外键关联表的信息,可以利用`all_constraints`视图和`all_cons_columns`视图进行...
主键和外键都是Oracle等关系型数据库管理系统(RDBMS)中的重要概念。 **主键**是定义一个表中起主要作用的数据项,它确保这些数据项在表中的唯一性。主键的特性包括: 1. 唯一性:主键的值在表中必须是唯一的,不...
Oracle 查询用户所有表的语句是数据库管理中非常重要的一部分,本文为您介绍了查询用户所有表的语句,包括查询所有用户的表、视图等信息、查询本用户的表、视图等信息、查询所有用户的表的列名和注释信息等。
成绩表中的学号虽然不是成绩表的主键,但它与学生表中的学号相对应,并且学生表中的学号是学生表的主键,这时成绩表中的学号就是学生表的外键。同理,成绩表中的课程号是课程表的外键。 #### 二、主键、外键和索引...
在数据库设计中,主键和外键是确保数据完整性和一致性的重要工具,特别是在Oracle这样的关系型数据库管理系统中。主键和外键的概念以及它们的作用对于理解数据库的结构和操作至关重要。 首先,主键是表的一个或多个...
在Oracle中,创建主键会自动为该列创建索引,以确保数据查询和更新的效率。 在上述示例中,我们有两个表,一个是`pk_t`(父表),另一个是`fk_t`(子表)。父表`pk_t`拥有主键约束,子表`fk_t`有一个外键约束,引用...
- 不是所有查询都受益于索引,对于全表扫描或者不使用索引列的查询,索引可能反而增加系统负担。 - 使用`EXPLAIN PLAN`或`SQL Profiler`来分析查询性能,确定是否需要添加或调整索引。 **总结:** Oracle约束和...
这些对象包括用户、表视图、索引、表空间、同义词、存储过程和函数以及约束条件。接下来,我们将深入探讨这些概念及其在实际工作中的应用。 **用户**: Oracle数据库中的用户是具有特定权限的角色,用于组织数据的...
- **DBA_CONSTRAINTS/ALL_CONSTRAINTS/USER_CONSTRAINTS**:提供关于表上定义的所有约束信息,包括主键、外键、唯一性约束等。 - **DBA_CONS_COLUMNS/ALL_CONS_COLUMNS/USER_CONS_COLUMNS**:提供关于每个约束所...
- Oracle:`create index 索引名 ON 表名 (列名)` - MySQL:`create index 索引名 ON 表名 (列名)`(普通索引),`create unique index 索引名 ON 表名 (列名)`(唯一索引) 17. **删除索引**: - SQL Server:`...
本文主要探讨了表结构和索引对Oracle查询效率的影响,这对于数据库管理员和开发人员在设计和优化数据库时具有很高的参考价值。 首先,表结构的设计直接影响着查询效率。合理的表结构可以减少数据冗余,提高数据一致...
参照完整性(如外键约束),保证引用的外键值存在于被引用表的主键中;或者用户自定义完整性,如检查约束,确保数据符合特定条件。约束帮助防止错误数据的输入,保证数据质量。 SQL是标准的关系型数据库查询语言,...
Excel的便利性和灵活性使得用户可以方便地编辑和调整表结构,如添加、删除或修改列,设置主键、外键和索引等。工具会读取这些信息并自动生成相应的SQL脚本。 在使用这个工具时,用户首先需要在Excel中创建一个模板...
- `SELECT * FROM all_tab_comments`:这个查询返回所有用户的表、视图的名称和相关注释。 - `SELECT * FROM user_tab_comments`:相反,它只返回当前用户的表和视图的元数据。 2. **查询列名和注释**: - `...
2. **表结构迁移**:迁移表结构主要包括创建表、定义字段、主键、外键、索引等。C#代码可以通过ADO.NET或者其他数据库访问库连接到SQL Server和Oracle,读取SQL Server的表结构,然后在Oracle中创建相应的表。 3. *...
3. **多对多**:两个表之间存在多对多的关系时,通常会引入第三个表(关联表)来连接它们,该关联表中包含两个表的主键作为其外键。 #### 四、触发器的设置 触发器是一种特殊类型的存储过程,它被定义为当特定事件...