Oracle数据库创建视图及概念(详细教程)
创作时间:
作者:
@小白创作中心
Oracle数据库创建视图及概念(详细教程)
引用
CSDN
1.
https://blog.csdn.net/qq_62145851/article/details/137235291
视图是数据库中一个非常重要的概念,它允许用户以虚拟表的形式查看数据,而无需了解数据的实际存储方式。通过视图,可以简化复杂的查询操作,提高数据访问的安全性和效率。本文将详细介绍Oracle数据库中视图的概念、创建方法以及与表的区别,帮助读者全面理解这一重要功能。
视图的概念
视图(view)类似一个虚表,建立与基表之上。不会占用物理的空间(还有一种占用物理空间的视图叫做物化视图MATERIALIZED VIEW,物化视图又称快照),视图的定义语句会存储在数据字典中,会根据基表的更新而更新数据,而一个视图当然也可以从另一个视图中产生,相当于把一个SQL语句打包起来然后起一个别名,在你查询这个视图内容的时候,视图对应的SQL会再执行一次,然后把结果反馈给你,也就是将你写的SQL的结果封装成一张虚拟表,基于它创建时指定的SQL语句返回的结果集。
需要注意的是,对于视图的操作其实是对视图对应SQL内字段所属基表的操作,虽然可能会受到一些限制。单表视图是可以增删改的。
视图的优点
- 便捷整合:不用害怕丢失SQL语句。对于需要多次执行的SQL,在权限允许的情况下也可以建一个视图。有些SQL分组统计以后需要连接另一张表,那么就可以建一个视图用视图去连接。
- 保密:有些表内的隐私字段或敏感字段,如果不希望使用者看见,就可以把使用者需要使用的字段创建一个视图。这样使用者就不知道基表,以及基表的表结构
- 简化权限:不用对于不同用户去授予表字段权限,而是直接建视图,将视图的权限给对应用户就可以。
视图的缺点
- 耗费时间:因为需要把视图的查询转换为基本表的查询。
- 修改不便:需要把对于视图的操作转换为对基表的操作,简单的视图会比较方便但是复杂视图会繁琐和限制比较多。
- 单表视图:增删改查
- 多表视图:只能修改和查询
视图与表的区别
- 视图不占用物理空间,而表是占用物理空间的。
- 表是内容,而视图是一个窗口。
- 视图的建立和删除只影响自身而不影响表。
视图的语法
SQL语句推荐使用大写-个人建议
查询所有视图
SELECT * FROM ALL_VIEWS WHERE OWNER LIKE 用户;
--VIEW_NAME(视图名)
--TEXT(AS后面那一段SQL)
创建视图
CREATE [OR REPLACE] VIEW 视图名 AS SQL语句;
示例
创建一个学生表
CREATE TABLE STUDENT (
SNO VARCHAR(3) NOT NULL,
SNAME VARCHAR(8) NOT NULL,
SSEX VARCHAR(2) NOT NULL,
SBIRTHDAY DATE DEFAULT NULL,
SCLASS VARCHAR(5) DEFAULT NULL);
---------------------------------------
INSERT INTO STUDENT (SNO, SNAME, SSEX, SBIRTHDAY, SCLASS)
VALUES ('101', '李军', '男',SYSDATE, '95033');
INSERT INTO STUDENT (SNO, SNAME, SSEX, SBIRTHDAY, SCLASS)
VALUES ('103', '陆君', '男', SYSDATE, '95031');
INSERT INTO STUDENT (SNO, SNAME, SSEX, SBIRTHDAY, SCLASS)
VALUES ('105', '匡明', '男',SYSDATE, '95031');
INSERT INTO STUDENT (SNO, SNAME, SSEX, SBIRTHDAY, SCLASS)
VALUES ('107', '王丽', '女',SYSDATE, '95033');
INSERT INTO STUDENT (SNO, SNAME, SSEX, SBIRTHDAY, SCLASS)
VALUES ('108', '曾华', '男',SYSDATE, '95033');
INSERT INTO STUDENT (SNO, SNAME, SSEX, SBIRTHDAY, SCLASS)
VALUES ('109', '王芳', '女',SYSDATE, '95031');
---------------------------------------
SELECT * FROM STUDENT;
创建一个成绩表
CREATE TABLE SCORE (
SNO VARCHAR(3) NOT NULL,
CNO VARCHAR(5) NOT NULL,
DEGREE DECIMAL(4, 1) DEFAULT NULL);
---------------------------------------
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('101', '3105', '64.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('101', '6166', '85.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('103', '3105', '92.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('103', '3245', '86.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('105', '3105', '88.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('105', '3245', '75.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('107', '3105', '91.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('107', '6166', '79.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('108', '3105', '78.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('108', '6166', '81.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('109', '3105', '76.0');
INSERT INTO SCORE (SNO, CNO, DEGREE)
VALUES ('109', '3245', '68.0');
---------------------------------------
SELECT * FROM SCORE;
创建视图
CREATE OR REPLACE VIEW TOTAL_ AS
SELECT 学号, 姓名, 总分, RANK() OVER(ORDER BY 总分 DESC) 排名
FROM (SELECT A.SNO 学号,
A.SNAME 姓名,
ROUND(SUM(NVL(B.DEGREE, 0)), 2) 总分
FROM STUDENT A, SCORE B
WHERE A.SNO = B.SNO
AND SSEX IN ('男', '女')
GROUP BY A.SNO, A.SNAME)
删除表(工作中先查后删,避免删错,这是很重要的)
DROP TABLE 表名;
删除视图
DROP VIEW 视图名;
热门推荐
查文红:一位上海退休女工的砀山支教之路
腹式呼吸法:简单有效的助眠神器
睡前两小时养生法,你get了吗?
喝杯热牛奶,今晚睡个好觉!
中国睡眠研究会发布:这些睡前习惯助你一夜好眠!
热“雪”沸腾!哈工程以科技创新助力亚冬会
如何停止磨牙:原因、症状与解决方案全解析
儿童口腔粘膜病小知识
孩子夜间经常磨牙怎么处理?
無論大人還小朋友,10個最適合睡覺磨牙解決方法
大运会上热搜的花花,揭秘熊猫爪子的秘密
揭秘大熊猫“拇指”进化之谜:从伪拇指到竹子专家
揭秘大熊猫“六指琴魔”的爪子秘密
混动车保养秘籍大揭秘!
威海到大连5天自驾游:网红打卡点全攻略!
生菜炒鸡蛋和酱炒鸡蛋:简单美味的家常菜新宠
青菜鸡蛋新吃法:韭菜、番茄、蒜头大比拼!
青菜炒鸡蛋的创新搭配与烹饪技巧
《极速之星》:当芭蕾舞者遇上500公里时速的赛车
清朝黑丝:东西方时尚交流的见证
纲手黑丝造型爆红,你被圈粉了吗?
探究黄芪搭配普洱茶同饮的适宜性与功效
鹿目圆的白丝魅力大揭秘:从审美符号到角色灵魂
白丝、紫色上衣和高跟鞋:打造优雅时尚造型的绝美搭配
沙雕模拟器playmods修改菜单:让你的游戏体验飞起!
《沙雕模拟器》新版本上线:趣味玩法大揭秘!
我国科学家取得全固态锂电池研究新突破
揭秘“山羊人”:从古希腊神话到中国乡村的神秘传说
牧神潘:古希腊神话中的山羊人传奇
天津必打卡:庆王府&邮政博物馆