Oracle视图

视图--查询

视图与表的区别:

1. 表需要占用磁盘空间,视图不需要

2. 视图不能添加索引

3. 使用视图可以简化复杂查询,如学生选课系统

4. 视图利于提高安全性,如不同用户查看不同的视图

-- 假设管理员创建了一个用户:xiaohong,
-- 现在只希望小红可以查询sal<1000的那些雇员

-- 视图,给xiaohong授权sal<1000的视图权限
-- 假设管理员创建了一个用户:xiaohong,
-- 现在只希望小红可以查询sal<1000的那些雇员

-- 视图,给xiaohong授权sal<1000的视图权限

-- 创建一个视图,把emp表的 sal<1000的雇员,映射到视图
create view my_view as select * from emp where sal<1000;
-- 为了简化操作,用一个视图解决 显示雇员号,姓名和部门名称

create or replace view my_view as
  select emp.empno,emp.ename,dept.dname from emp,dept where emp.deptno=dept.deptno;
-- 删除视图
drop view my_view;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 视图(View)是一种虚拟表,是基于一个或多个基础表(Base Table)的查询结果集的命名表示。在 Oracle 数据库中,可以通过创建视图来简化复杂的查询,隐藏实际表的结构和数据,以及提供安全性和数据独立性。 以下是 Oracle 视图的创建语法: ```sql CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name [(alias1, alias2, ...)] AS select_statement; ``` 其中, - `OR REPLACE`:如果视图已经存在,则用新的定义替换。 - `FORCE`:如果基础表不存在或者视图依赖的对象无效,则仍然创建视图。 - `NOFORCE`:如果基础表不存在或者视图依赖的对象无效,则不创建视图。 - `view_name`:视图的名称。 - `alias1, alias2, ...`:列别名,可以省略。 - `select_statement`:查询语句,用于定义视图。 例如,创建一个简单的视图: ```sql CREATE VIEW emp_view AS SELECT empno, ename, job, sal FROM emp WHERE deptno = 10; ``` 在创建视图后,可以像查询表一样使用视图: ```sql SELECT * FROM emp_view; ``` 还可以在视图中使用聚合函数、子查询、连接等高级语法,例如: ```sql CREATE VIEW dept_sal_view AS SELECT d.dname, SUM(e.sal) AS total_sal FROM dept d, emp e WHERE d.deptno = e.deptno GROUP BY d.dname; ``` 在使用视图时,可以像查询表一样使用它: ```sql SELECT * FROM dept_sal_view; ``` 总之,Oracle 视图是一种非常方便的工具,可以简化复杂的查询,隐藏实际表的结构和数据,提供安全性和数据独立性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值