1.创建视图

介绍:

视图(View)通过SELECT查询语句定义,它是从一个或多个表(或视图)导出的,用来导出视图的表称为基表(Base Table),导出的视图称为虚表。在数据库中,只存储视图的定义,不存放视图对应的数据,这些数据仍然存放在原来的基表中。
视图可以由一个基表中选取的某些行和列组成,也可以由多个表中满足一定条件的数据组成,视图就像是基表的窗口,它反映了一个或多个基表的局部数据。

语法:

CREATE [ OR REPLACE ] [FORCE | NOFORCE] VIEW [<用户方案名>.]<视图名> [ ( <列名> [ ,…n ] ) ]
  AS
  <SELECT查询语句>
  [WITH CHECK OPTION[CONSTRAINT <约束名>]]
  [WITH READ ONLY]

说明:
● OR REPLACE:在创建视图时,如果存在同名视图,则要重新创建。
● 用户方案名:默认为当前账号。
● 列名:可以自定义视图中包含的列,若使用源表或视图中相同的列名,可不必给出列名。
● SELECT查询语句:定义视图的SELECT语句,可查询多个表或视图。
● CONSTRAINT:约束名称。
● WITH CHECK OPTION:指出在视图上进行的修改都要符合SELECT语句所指定的限制条件。

示例:

使用SQL Developer,在stsys数据库中创建vwStudentCourseScore视图,包括学号、姓名、性别、课程名、成绩,按学号升序排列,且专业为计算机。

CREATE OR REPLACE VIEW vwStudentScore
  AS
  SELECT a.sno, a.sname, a.ssex, a.speciality, b.cname, c.grade
    FROM student a, course b, score c
    WHERE a.sno=c.sno AND b.cno=c.cno AND a.speciality='计算机'
    ORDER BY a.sno
    WITH CHECK OPTION;

使用CREATE VIEW语句,在stsys数据库中创建vwStudentScore视图,包括学号、姓名、性别、专业、课程号、成绩,且专业为计算机。

CREATE OR REPLACE VIEW vwStudentScore
  AS
  SELECT a.sno, a.sname, a.ssex, a.speciality, b.cno, b.grade
    FROM student a, score b
    WHERE a.sno=b.sno AND a.speciality='计算机'
    WITH CHECK OPTION;

2.查询视图

介绍:

查询视图跟查询表类似

示例:

分别查询vwStudentCourseScore视图、vwStudentScore 视图。使用SELECT语句对vwStudentCourseScore视图进行查询

SELECT *
  FROM vwStudentCourseScore;
SELECT *
  FROM vwStudentScore;

查询计算机专业学生的学号、姓名、性别、课程名。

SELECT sno, sname, ssex, cname FROM vwStudentCourseScore;

3.更新视图

3.1创建可更新的视图

示例:

以student为基表,创建专业为通信的可更新视图vwCommSpecialityStudent。

create or replace view vwCommSpecialityStudent
  as
  select * from student where speciality='通信';

3.2插入数据

示例:

向vwCommSpecialityStudent视图中插入一条记录:('124005','刘启文','男','1992-06-19','通信','201236',50)。

insert into vwcommspecialitystudent values('124005','刘启文','男',TO_DATE('19920619','YYYYMMDD'),'通信','201236',50);
select * from vwCommSpecialityStudent;
select * from student;

3.3修改数据

示例:

将vwCommSpecialityStudent视图中学号为124005的学生的总学分增加2分。

update vwcommspecialitystudent set tc=tc+2 where sno='124005';
select * from student;

3.4删除数据

示例:

删除vwCommSpecialityStudent视图中学号为124005的记录。

delete from vwcommspecialitystudent where sno='124005';

4.修改视图定义

介绍:
修改视图的定义只能通过 create or replace view 覆盖表

示例:

将视图vwStudentScore进行修改,取消专业为计算机的要求。

CREATE OR REPLACE VIEW vwStudentScore
  AS
  SELECT a.sno, a.sname, a.ssex, a.speciality, b.cno, b.grade
    FROM student a, score b
    WHERE a.sno=b.sno
    WITH CHECK OPTION;

5.删除视图

语法:

DROP VIEW <视图名>

示例:

将视图vwStudentCourseScore删除。

DROP VIEW vwStudentCourseScore;

6.综合训练

(1)创建一个视图vwClassStudentCourseScore,包含学号、姓名、性别、班级、课程号、课程名和成绩等列,班级为201236,并查询视图的所有记录。

create or replace view vwClassStudentCourseScore
  as
  select a.sno,a.sname,a.ssex,a.sclass,b.cno,c.cname,b.grade
    from student a,score b,course c where a.sno=b.sno and b.cno=c.cno and a.sclass='201236';

(2)创建一个视图vwCourseScore,包含学生学号、课程名、成绩等列,然后查询该视图的所有记录。

create or replace view vwCourseScore
  as
  select b.sno,c.cno,b.grade from score b,course c where b.cno=c.cno;

(3)创建一个视图vwAvgGradeStudentScore,包含学生学号、姓名、平均分等列、按平均分降序排列,再查询该视图的所有记录。

create or replace view vwAvgGradeStudentScore
  as
  select a.sno,a.sname,b.avg_grade
    from student a,(select sno,AVG(grade) avg_grade from score GROUP BY sno ORDER BY avg_grade DESC) b where a.sno=b.sno;
select * from vwAvgGradeStudentScore;

04-oracle中的视图的更多相关文章

  1. Oracle中创建视图

    Oracle的数据库对象分为五种:表,视图,序列,索引和同义词. 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表. 视图是存储在数 ...

  2. oracle中普通视图和实体试图的区别

    Oracle普通视图和实体化视图比较 来源:茂盛博客|2013-07-30 Oracle普通视图和实体化视图比较 相对于普通的视图来说,实体化视图的不同之处在于实体化视图管理存储数据,占据数据库的物理 ...

  3. Oracle中添加视图

     CREATE or REPLACE view view_will as   select college.collegeid,mat.stuid,sum(score.chinese+score.ma ...

  4. 转: Oracle中的物化视图

    物化视图创建语法:CREATE MATERIALIZED VIEW <schema.name>PCTFREE <integer>--存储参数PCTUSED <intege ...

  5. Oracle中建立物化视图报错

    Oracle中建立物化视图报错 今天在建立视图的时候,报了一个错:ORA-01723: zero-length columns are not allowed. 建视图的语句: create mate ...

  6. ubuntu14.04系统中virtualbox安装Oracle VM VirtualBox Extension Pack包

    ubuntu14.04系统中virtualbox默认不支持usb设备,需要安装Oracle VM VirtualBox Extension Pack才行,但必须安装以下版本才可以安装成功: Oracl ...

  7. ORACLE中dba,user,v$等开头的常用表和视图

    一.Oracle表明细及说明1.dba_开头表    dba_users           数据库用户信息    dba_segments    表段信息    dba_extents        ...

  8. oracle中有关初始化参数文件的几个视图对比

    涉及oracle中有关初始化参数文件的几个视图主要有:v$paraemter,v$parameter2,v$system_parameter,v$system_parameter2,v$spparam ...

  9. Oracle中-事务-序列-视图-数据类型笔记

    事务(Transaction) 事务(Transaction)是一个操作序列.这些操作要么都做,要么都不做,是一个不可分割的工作单位,是数据库环境中的逻辑工作单位. 事务是为了保证数据库的完整性 在o ...

  10. oracle中视图v$sql的用途

    1.获取正在执行的sql语句.sql语句的执行时间.sql语句的等待事件: select a.sql_text,b.status,b.last_call_et,b.machine,b.event,b. ...

随机推荐

  1. Android 之文件夹排序

    按文件名排序 /** * 按文件名排序 * @param filePath */ public static ArrayList<String> orderByName(String fi ...

  2. 关于如何使用xposed来hook微信软件

     安卓端  难点有两个  收款码的生成和到帐监听   需要源码加 2442982910

  3. web测试之功能测试总结

    web测试是什么? web测试就是基于BS架构的软件产品的测试,通俗点来说就是web网站的测试 web功能测试包括哪些方面? 功能测试主要包括6大部分: 1.链接测试 2.表单测试 3.搜索测试 4. ...

  4. QC API全系列揭秘之Test Execution操作(全网首发)

    (原创文章,转载请注明出处.) 一.QC简介: Quality Center存在至今已经走过了10多个年头,名字从一开始的TD,到后来的QC,再到现在的ALM.所属公司从开始的Mercury到现在的H ...

  5. [转]Lua和Lua JIT及优化指南

    一.什么是lua&luaJit lua(www.lua.org)其实就是为了嵌入其它应用程序而开发的一个脚本语言, luajit(www.luajit.org)是lua的一个Just-In-T ...

  6. L2TP连接尝试失败,因为安全层在初始化与远程计算机的协商时遇到了一个处理错误(转)

    L2TP连接尝试失败,因为安全层在初始化与远程计算机的协商时遇到了一个处理错误   错误描述:“ L2TP连接尝试失败,因为安全层在初始化与远程计算机的协商时遇到了一个处理错误” 只有这个没有错误码. ...

  7. Python基础之函数和模块

    函数的基本使用 函数的定义:把具有独立功能的代码块组织成一个小模块,在需要的时候调用.或者说,函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数的使用:1.定义函数:2.调用函数 ...

  8. python学习_1

    1.python2和python3 从宏观上讲,python2源码不标准.混乱.重复,和龟叔的理念背道而驰. 在python3上,实现了源码的统一化和标准化,去除了重复的代码. 2.编译型语言和解释型 ...

  9. java.util.Arrays.useLegacyMergeSort=true 作用

    (原) 今天看了一下现场的环境,发现有个其它部门的项目用到了这样一个参数: -Djava.util.Arrays.useLegacyMergeSort=true 于是查看了一下什么作用. 在JDK1. ...

  10. C# web项目利用docx文档作为模板~为打印专做的解决方案

    还是那句话:十年河东,十年河西,莫欺少年穷. 目前,web端打印技术有很多,有收费的专业web打印控件,大家可以参考我的上一篇博客.当然,很多公司不愿意出钱,那么今天咱们就探讨下怎么做免费的打印. w ...