9_mysql视图

① 视图(view)是从一个或多个表中(或视图)导出的表。
② 视图与表(有时为与视图区别,也称表为基本表)不同,视图是一个虚表,即对它所对应的数据不进行实际的存储,数据库中只存储视图的定义,对视图的数据进行操作时,系统根据视图的定义去操作与视图相关联的基本表。
③ 视图一经定义后,就可以像表一样被查询、修改、删除、更新。


  1. 视图的优点
  • 为用户集中数据,简化用户的数据查询和处理
  • 屏蔽数据库的复杂性
  • 简化用户权限的管理
  • 便于数据共享
  • 可以重新组织数据以便输出到其他应用程序中

  1. 创建视图

CREATE
[OR REPLACE]
[ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
[DEFINER = { user | CURRENT_USER }]
[SQL SECURITY { DEFINER | INVOKER }]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]

  • OR REPLACE:给定了OR REPLACE子句,语句能够替换已有的同名视图。
  • ALGORITHM子句:可选的ALGORITHM子句是对标准SQL的MySQL扩展,规定了MySQL的算法,算法会影响MySQL处理视图的方式。
  • view_name:视图名。
  • column_list:要想为视图的列定义明确的名称,可使用可选的column_list子句,列出由逗号隔开的列名。
  • select_statement:用来创建视图的SELECT语句,可在SELECT语句中查询多个表或视图。
    注意:
    ① 定义视图的用户必须对所参照的表或视图有查询(即可执行select语句)权限;
    ② 不能包含from子句中的子查询
    ③ 不能引用系统或用户变量
    ④ 不能引用预处理语句参数
    ⑤ 在定义中引用的表或视图必须存在
  • WITH CHECK OPTION:指出在可更新视图上所进行的修改都要符合select_statement所指定的限制条件,这样可以确保数据修改后,仍可通过视图看到修改的数据。
    使用视图时,要注意下列事项:
    ① 在默认情况下,将在当前数据库创建新视图。要想在给定数据库中明确创建视图,创建时,应将名称指定为db_name.view_name。
    ② 视图的命名必须遵循标志符命名规则,不能与表同名,且对每个用户视图名必须是唯一的,即对不同用户,即使是定义相同的视图,也必须使用不同的名字。
    不能把规则、默认值或触发器与视图相关联
    不能在视图上建立任何索引,包括全文索引

举例一:假设当前数据库是test,创建xscj数据库上的cs_kc视图,包括计算机专业各学生的学号、其选修的课程号及成绩。要保证对该视图的修改都符合专业名为“计算机”这个条件。

create or replace view  xscj.cs_kc 
    as
    select xs.学号,课程号,成绩
         from xscj.xs,  xscj.xs_kc
         where  xs.学号 = xs_kc.学号 and xs.专业名 = '计算机'
         with check option;

举例二:创建xscj数据库上的计算机专业学生的平均成绩视图cs_kc_avg,包括学号(在视图中列名为num)和平均成绩(在视图中列名为score_avg)

use xscj
create view cs_kc_avg(num, score_avg)
    as
    select 学号,avg(成绩)
         from cs_kc
         group by 学号;

  1. 删除视图

DROP VIEW [IF EXISTS] view_name [, view_name] ...

view_name是视图名,声明了IF EXISTS,若视图不存在的话,也不会出现错误信息。使用DROP VIEW一次可删除多个视图。
drop view cs_xs;


  1. 修改视图
    举例:将cs_xs视图修改为只包含计算机专业学生的学号、姓名和总学分三列。
alter view cs_xs
as
    select 学号,姓名,总学分
         from xs
         where 专业名 = '计算机';

  1. 查询视图
    视图定义后,就可以如同查询基本表那样对视图进行查询
    举例:查找平均成绩在80分以上的学生的学号和平均成绩。
## 创建学生平均成绩视图xs_kc_avg:
create view xs_kc_avg ( num,score_avg )
   as 
   select 学号, avg(成绩)
      from xs_kc
      group by 学号;
## 再对xs_kc_avg视图进行查询。
select *
   from xs_kc_avg
   where score_avg>=80;

  1. 更新视图(视图数据的插入、修改、删除)

由于视图是一个虚拟表,所有更新视图(包括插入、修改和删除)数据也就等于在更新与其关联的基本表的数据。

  • 可更新的视图
    在视图中的行和基本表中的行之间必须具有一对一的关系。如果视图中包含下述结构中的任何一种,那么它就是不可更新的:
    (1)聚合函数;
    (2)DISTINCT关键字;
    (3)GROUP BY子句;
    (4)ORDER BY子句;
    (5)HAVING子句;
    (6)UNION运算符;
    (7)位于选择列表中的子查询;
    (8)FROM子句中包含多个表;
    (9)SELECT语句中引用了不可更新视图;
    (10)WHERE子句中的子查询,引用FROM子句中的表;
    (11)ALGORITHM 选项指定为TEMPTABLE(使用临时表总会使视图成为不可更新的).
  • 插入数据
    举例:创建视图cs_xs,视图中包含计算机专业的学生信息,并向cs_xs视图中插入一条记录:('081255','李牧','计算机',1,'1994-10-21',50,NULL,NULL)。
# 首先创建视图cs_xs:
create or replace view cs_xs
    as 
    select *
         from xs
         where 专业名 = '计算机'
    with check option;
# 接下来插入记录:
insert into cs_xs
   values('081255', '李牧', '计算机', 1, '1994-10-14', 50, null, null);
  • 修改数据
    举例一:将cs_xs视图中所有学生的总学分增加8分。
update cs_xs
    set 总学分 = 总学分+ 8;
若一个视图依赖于多个基本表,则一次修改该视图只能变动一个基本表的数据。

举例二:将cs_kc视图中学号为081101的学生的101课程成绩改为90分。

update cs_kc
    set 成绩=90
    where 学号='081101' and 课程号='101';
# 比如,以下的修改就是错误的:
update cs_kc
    set 学号='081120',课程号='208'
    where 成绩=90;
  • 删除数据
    举例:删除cs_xs中李牧同学(学号'081255',【例4.74】插入)的记录。
delete from cs_xs
    where 学号 = '081255';

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342