04-oracle中的视图
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中的视图的更多相关文章
- Oracle中创建视图
Oracle的数据库对象分为五种:表,视图,序列,索引和同义词. 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表. 视图是存储在数 ...
- oracle中普通视图和实体试图的区别
Oracle普通视图和实体化视图比较 来源:茂盛博客|2013-07-30 Oracle普通视图和实体化视图比较 相对于普通的视图来说,实体化视图的不同之处在于实体化视图管理存储数据,占据数据库的物理 ...
- Oracle中添加视图
CREATE or REPLACE view view_will as select college.collegeid,mat.stuid,sum(score.chinese+score.ma ...
- 转: Oracle中的物化视图
物化视图创建语法:CREATE MATERIALIZED VIEW <schema.name>PCTFREE <integer>--存储参数PCTUSED <intege ...
- Oracle中建立物化视图报错
Oracle中建立物化视图报错 今天在建立视图的时候,报了一个错:ORA-01723: zero-length columns are not allowed. 建视图的语句: create mate ...
- ubuntu14.04系统中virtualbox安装Oracle VM VirtualBox Extension Pack包
ubuntu14.04系统中virtualbox默认不支持usb设备,需要安装Oracle VM VirtualBox Extension Pack才行,但必须安装以下版本才可以安装成功: Oracl ...
- ORACLE中dba,user,v$等开头的常用表和视图
一.Oracle表明细及说明1.dba_开头表 dba_users 数据库用户信息 dba_segments 表段信息 dba_extents ...
- oracle中有关初始化参数文件的几个视图对比
涉及oracle中有关初始化参数文件的几个视图主要有:v$paraemter,v$parameter2,v$system_parameter,v$system_parameter2,v$spparam ...
- Oracle中-事务-序列-视图-数据类型笔记
事务(Transaction) 事务(Transaction)是一个操作序列.这些操作要么都做,要么都不做,是一个不可分割的工作单位,是数据库环境中的逻辑工作单位. 事务是为了保证数据库的完整性 在o ...
- oracle中视图v$sql的用途
1.获取正在执行的sql语句.sql语句的执行时间.sql语句的等待事件: select a.sql_text,b.status,b.last_call_et,b.machine,b.event,b. ...
随机推荐
- C语言字符数组回顾
赋值篇: Part1 错误引例*2: char c6[];//WRONG c6="HELLO";//WRONG char c7[];//WRONG c7[]='H';// ...
- 专注于C#.Net WPF软件开发-软件反编译-软件破解-逆向-靖芯科技-包括安卓APK反编译
靖芯科技提供.Net软件开发,软件修改定制二次开发,软件破解,反编译,逆向等各项优质服务: 包括安卓APK软件反编译. 包括但不限于C#,WPF,Surface,Winform,Asp.net.JAV ...
- java中的重写与重载
重写(Override) 重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变.即外壳不变,核心重写! 重写的好处在于子类可以根据需要,定义特定于自己的行为. 也就是说子类 ...
- web安全—sql注入漏洞
SQL注入-mysql注入 一.普通的mysql注入 MySQL注入不像注入access数据库那样,不需要猜.从mysql5.0以上的版本,出现一个虚拟的数据库,即:information_schem ...
- 【java学习】Intelli Idea集成开发工具的使用
== mac版直接下载地址: https://download.jetbrains.com/idea/ideaIU-2018.1.6.dmg ==mac配置java环境变量: https://ji ...
- SpringBoot中使用JNnit4(入门篇)
一.添加依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...
- lvds接口介绍
1.项目简介 用索尼的imx264 sensor采集图像,在内部模数转换之后,由lvds接收,然后解码,最后送给后端显示 2.框图 imx264配置成从模式,由spi总线配置,需要由FPGA提供 行. ...
- 第二部分之Redis服务器(第十四章)
Redis服务器复制和多个客户端建立网络连接,处理客户端发送的命令请求,在数据库中保存客户端执行命令所产生的数据. 一,命令请求的执行过程 客户端向服务器发送命令请求 set key value 服务 ...
- Windows之常用命令
1. 重启/关机 shutdown命令 #关机 shutdown -s -t -f #重启 shutdown -r -t //30秒之后,重启 00是立即 #注销 shutdown -l -t #休眠 ...
- Hexo之傻瓜攻略
Hexo搭建个人技术博客的网站,从零开始流程 搭建篇 必备Node.js环境 安装配置hexo: npm install -g hexo 安装cli hexo init 初始化hexo npm ins ...