Oracle视图(view)创建使用

视图是一张虚拟表,其内容由查询定义,同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。(视图不是真实存在磁盘上的)

一、视图与表的区别

1、表需要占用磁盘空间,视图不需要
2、视图不能添加索引(所以查询速度略微慢点)
3、使用视图可以简化,复杂查询
4、视图的使用利于提高安全性
比如:不同用户查看不同视图

创建,修改,删除视图的基本操作

二、创建视图

语法结构:

CREATE [OR REPLACE] [{FORCE|NOFORCE}] VIEW   视图名

AS

SELECT查询   (需要查询的结果)                                       

[WITH READ ONLY CONSTRAINT] (设置是否可以对视图进行增删改查)

 

语法解析:

1. OR REPLACE:如果视图已经存在,则替换旧视图。

2. FORCE:即使基表不存在,也可以创建该视图,但是该视图不能正常使用,当基表创建成功后,视图才能正常使用。

3. NOFORCE:如果基表不存在,无法创建视图,该项是默认选项。

4. WITH READ ONLY:默认可以通过视图对基表执行增删改操作,但是有很多在基表上的限制(比如:基表中某列不能为空,但是该列没有出现在视图中,则不能通过视图执行insert操作),WITH READ ONLY说明视图是只读视图,不能通过该视图进行增删改操作。现实开发中,基本上不通过视图对表中的数据进行增删改操作。

三、删除视图

1、drop view 视图名

四、案例分析

1、查询视图数据和查询基表的数据的sql一样

 

  • 3
    点赞
  • 43
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 数据库中,物理视图是一个基于表或者其他物理视图的查询结果集,它以虚拟表的形式存在,并且提供了对数据的访问和操作。创建物理视图是为了方便用户在访问数据时能够一次性获取多个表或者视图的数据。下面是创建 Oracle 物理视图的实例。 首先,我们需要登录到 Oracle 数据库。 接下来,我们使用 CREATE VIEW 语句来创建物理视图。这里我们需要指定视图的名称以及定义视图所基于的查询语句。例如,我们可以创建一个名为 EMPLOYEES_VIEW视图,它基于 EMPLOYEES 表和 DEPARTMENTS 表的联接查询: CREATE VIEW EMPLOYEES_VIEW AS SELECT e.EMPLOYEE_ID, e.FIRST_NAME, e.LAST_NAME, d.DEPARTMENT_NAME FROM EMPLOYEES e JOIN DEPARTMENTS d ON e.DEPARTMENT_ID = d.DEPARTMENT_ID; 在创建物理视图时,我们可以选择使用 WITH CHECK OPTION 子句来限制对视图的修改操作。这样,只有满足视图定义条件的数据才能被插入、更新或删除。例如: CREATE VIEW EMPLOYEES_SALARY_VIEW AS SELECT EMPLOYEE_ID, FIRST_NAME, LAST_NAME, SALARY FROM EMPLOYEES WHERE SALARY > 5000 WITH CHECK OPTION; 最后,创建物理视图后,我们就可以使用视图来查询数据。例如,可以使用以下 SELECT 语句从 EMPLOYEES_VIEW 视图中获取数据: SELECT * FROM EMPLOYEES_VIEW; 总结起来,创建 Oracle 物理视图的过程包括登录到数据库、使用 CREATE VIEW 语句定义视图的名称和查询语句,可以选择使用 WITH CHECK OPTION 子句限制对视图的修改操作,并且可以使用创建好的视图来查询数据。物理视图创建可以大大简化查询过程,提高数据访问的效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值