码迷,mamicode.com
首页 > 数据库 > 详细

Oracle 笔记之视图

时间:2015-08-30 18:02:26      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:oralce

1.什么是视图?

  视图(VIEW)也被称为虚表,即虚拟的表,是一组数据的逻辑表达

  视图对应于一条SELECT语句,结果集被赋予一个名字, 即视图名字

  视图本身不包含任何数据,只是映射到基表的一个查询语句,当基表数据发生变化,视图数据也随之发送变化

  作用:重用代码,保护数据

2.创建视图 需要有权限 GRANT CREATE VIEW  TO user scott;

CREATE VIEW view_name 别名

不包含函数 叫简单视图

包含函数 表达式 复杂视图

基于多个表 连接视图

OR REPLACE 更新视图 如果存在则替换

语法

CREATE OR REPLACE VIEW 视图名称 SELECT语句

隐藏列名称 在SELECT语句中增加别名

CREATE OR REPLACE VIEW v_emp_10 AS SELECT empno id, ename name,sal salary,deptno deptno FROM emp WHERE deptno=10;

查看视图结构 DESC 视图名称

增加别名后 只能用别名进行查询视图 SELECT 姓名,工资,工作 FROM v_emp_10;

增加 WITH CHECK OPTION 防止在简单视图模式下 插入脏数据到基表内

CREATE OR REPLACE VIEW v_emp_10 AS SELECT empno id,

ename name,sal salary,deptno deptno FROM emp WHERE deptno=10 WITH CHECK OPTION;

复杂视图的创建

CREATE VIEW v_emp_salary

AS

SELECT d.dname,

AVG(e.sal) avg_sal,

SUM(e.sal) sum_sal,

MAX(e.sal)max_sal,

MIN(e.sal) min_sal

FROM emp e JOIN dept d ON e.deptno =d.deptno GROUP BY d.dname;

复杂视图的查询

SELECT * FROM v_emp_salary;

复杂视图不允许DML操作


本文出自 “方文俊的IT技术博客” 博客,请务必保留此出处http://fangwenjun.blog.51cto.com/7806977/1689585

Oracle 笔记之视图

标签:oralce

原文地址:http://fangwenjun.blog.51cto.com/7806977/1689585

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!