您的当前位置:首页Oracle-视图,约束

Oracle-视图,约束

2023-11-11 来源:六九路网

试图:试图是数据库对象之一视图在sql语句中体现的角色与表一致,但它不是一张真是存在的表,只是对应了一个查询语句的结果集当试图对应的子查询中含有函数或者表达式时,那么必须指定别名试图根据对应的子查询分为:简单试图,复杂试图,连接试图简单试图:对应的子查询不含有函数,表达式,去重,分组复杂试图:不是简单实体的都是复杂试图连接试图:对应的子查询有多表连接查询,连接试图算作复杂试图简单试图可以进行DML操作,但是复杂试图不允许进行DML操作。对试图进行DML操作就是对试图数据来源的基础表进行操作虽然可以对简单试图进行DML操作,但是DML操作也不能违反基表的约束是简单试图的不当DML操作会污染基础表数据:对简单试图今次那个DML操作后,视图对基础表做出对应操作,但是影响的数据视图对其不可见时,就是对基础表的数据污染删除不存在数据污染情况为视图添加检查选项可以避免对基础表产生数据污染,检查选项要求对试图进行DML操作后该记录试图对其可见,否则不允许操作。对试图添加只读选项后,该试图不允许进行DML操作。数据字典,数据字典是一系列的表,这些表的数据时由数据库自行维护,记录的时一些清单信息,方便随时查看。USER_OBJECTS:记录用户创建说有数据库对象USER_VIEW:记录用户创建的所有试图USER_TABLES:记录用户创建的所有的表序列序列也是数据库对象之一,序列的作用是根据指定的规则生成一系列数字,序列通常是为了某张表的主键字段提供值使用主键:通常每张表都会有主键字段,该字段的值要求非空且唯一,使用该字段来确定表中的每一条记录使用序列提供了两个伪列:nextval:获取序列的下一个数字,第一次获取时返回的时start with 指定的数字,以后则是最后获取的数字加上步长的到的,nextval会导致序列发生步进,且不可回退CURRVAL:获取序列当前数字,即:最后一次生成的数字,新创建的序列需要至少调用一次nextval以后才可以使用currval不会发生序列的步进.索引:索引时数据库对象之一,作用是加快查询效率索引的创建与使用时数据库自行完成的,经常出现在where中的字段,或者去重,排序,关联条件的字段可以添加索引唯一性约束,唯一性约束要求该字段在整张表中每条记录的值都不允许重复,null除外。主键约束,主键约束要求字段非空且唯一,且一张表只能有一个主键约束。

Oracle-视图,约束

标签:生成   oracle   查询语句   重复   允许   个数   查看   可见   star   

小编还为您整理了以下内容,可能对您也有帮助:

oracle 查看约束

查看表的约束条件有三个视图:

1、dba_constraints、all_constraints、user_constraints。

2、其中:dba_constraints视图需要DBA权限才能查询。

3、all_constraints、user_constraints普通用户查询。

扩展资料:

Oracle数据库使用约束(constraints)来防止无效的数据进入表中,保护数据的实体完整行约束定义在表级,如果表与表之间有从属关系,约束可以防止表的删除,通过约束字段,强制用户在插入更新和删除数据时必须遵循一定的规则。

约束定义语法: create table 表名(字段名 数据类型 约束类型) 或 create table 表名(字段名1 数据类型,字段名2,数据类型 constraints 约束别名 约束类型 (字段))

在oracle中如何查询一张表的所有数据结构,包括字段,视图,索引,约束

user_constraints系统视图可以查询约束。user_indexes系统视图可以查询所有索引信息。

user_views系统视图可以查询所有视图信息。

如果用Java JDBC的话,通过JDBC API中的DataBaseMetaData和ResultSetMetaData也可以取到相关元数据信息。

Oracle数据库-视图的概念

   一 视图概念

  视图是原始数据库数据的一种变换 是查看表中数据的另外一种方式 可以将视图看成是一个移动的窗口 通过它可以看到感兴趣的数据

  视图是从一个或多个实际表中获得的 这些表的数据存放在数据库中 那些用于产生视图的表叫做该视图的基表 一个视图也可以从另一个视图中产生

  视图的定义存在数据库中 与此定义相关的数据并没有再存一份于数据库中 通过视图看到的数据存放在基表中

  视图看上去非常象数据库的物理表 对它的操作同任何其它的表一样 当通过视图修改数据时 实际上是在改变基表中的数据 相反地 基表数据的改变也会自动反映在由基表产生的视图中 由于逻辑上的原因 有些视图可以修改对应的基表 有些则不能(仅仅能查询)

   二 视图的作用

   * 简单性 看到的就是需要的 视图不仅可以简化用户对数据的理解 也可以简化他们的操作 那些被经常使用的查询可以被定义为视图 从而使得用户不必为以后的操作每次指定全部的条件

   * 安全性 通过视图用户只能查询和修改他们所能见到的数据 数据库中的其它数据则既看不见也取不到 数据库授权命令可以使每个用户对数据库的检索到特定的数据库对象上 但不能授权到数据库特定行和特定的列上 通过视图 用户可以被在数据的不同子集上

  使用权限可被在基表的行的子集上

  使用权限可被在基表的列的子集上  

  使用权限可被在基表的行和列的子集上  

  使用权限可被在多个基表的连接所限定的行上  

  使用权限可被在基表中的数据的统计汇总上

  使用权限可被在另一视图的一个子集上 或是一些视图和基表合并后的子集上

   * 逻辑数据性 视图可帮助用户屏蔽真实表结构变化带来的影响

   三 视图的安全性

  视图的安全性可以防止未授权用户查看特定的行或列 是用户只能看到表中特定行的方法如下

   在表中增加一个标志用户名的列

   建立视图 是用户只能看到标有自己用户名的行

   把视图授权给其他用户

   四 逻辑数据性

  视图可以使应用程序和数据库表在一定程度上 如果没有视图 应用一定是建立在表上的 有了视图之后 程序可以建立在视图之上 从而程序与数据库表被视图分割开来 视图可以在以下几个方面使程序与数据

   如果应用建立在数据库表上 当数据库表发生变化时 可以在表上建立视图 通过视图屏蔽表的变化 从而应用程序可以不动

   如果应用建立在数据库表上 当应用发生变化时 可以在表上建立视图 通过视图屏蔽应用的变化 从而使数据库表不动

   如果应用建立在视图上 当数据库表发生变化时 可以在表上修改视图 通过视图屏蔽表的变化 从而应用程序可以不动

lishixin/Article/program/Oracle/201311/16872

oracle怎样查看约束名?

查看表的约束条件有三个视图:

1、dba_constraints、all_constraints、user_constraints。

2、其中:dba_constraints视图需要DBA权限才能查询。

3、all_constraints、user_constraints普通用户查询。

4、例:select * from user_constraints。

5、Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。

6、Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。

7、是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。

显示全文