9_mysql视图

2020-06-08  本文已影响0人  那是个好男孩

① 视图(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]

举例一:假设当前数据库是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. 更新视图(视图数据的插入、修改、删除)

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

# 首先创建视图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);
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;
delete from cs_xs
    where 学号 = '081255';

上一篇下一篇

猜你喜欢

热点阅读