33.MySQL中的视图

目录

1.简介

2.创建视图

3.修改视图

4.删除视图

5.视图数据操作


1.简介

什么是视图:是从一个或多个表中导出来的表,它是一种虚拟存在的表,表的结构和数据都依赖于基本表。

视图的优点

  1. 简化查询语句:简化用户的查询操作,使查询更加快捷。

  2. 安全性:更方便的进行权限控制。

  3. 逻辑数据独立性:屏蔽真实表结构变化带来的影响。

2.创建视图

在默认情况下,新创建的视图保存在当前选择的数据库中。

若要明确指定在某个数据库中创建视图,在创建时应将名称指定为“数据库名.视图名”。

在SHOW TBLES的查询结果中会包含已经创建的视图。

视图创建后,MySQL就会在数据库目录中创建一个“视图名.frm”文件。

准备数据:

CREATE DATABASE mahaiwuji;
USE mahaiwuji;

CREATE TABLE grade(
    id INT(4) PRIMARY KEY,
    name VARCHAR(36) 
) ENGINE = INNODB DEFAULT CHARSET = utf8;

INSERT INTO grade VALUES(1,'一班');
INSERT INTO grade VALUES(2,'二班');

CREATE TABLE student(
    sid INT(4) PRIMARY KEY,
    sname VARCHAR(36),
    gid INT(4) NOT NULL
) ENGINE = INNODB DEFAULT CHARSET = utf8;

INSERT INTO student VALUES (1,'码海无际1',1);
INSERT INTO student VALUES (2,'码海无际2',2);
INSERT INTO student VALUES (3,'码海无际3',2);
INSERT INTO student VALUES (4,'码海无际4',2);
INSERT INTO student VALUES (5,'码海无际5',1);
INSERT INTO student VALUES (6,'码海无际6',1);
INSERT INTO student VALUES (7,'码海无际7',1);
INSERT INTO student VALUES (8,'码海无际8',2);

查询数据

SELECT sid,sname,gid FROM student LIMIT 3;

创建view_student视图(CREATE VIEW 视图名 AS SELECT语句)

CREATE VIEW view_student AS
SELECT sid,sname,gid FROM student LIMIT 3;
-- 等价于
CREATE VIEW view_student AS
SELECT * FROM student LIMIT 3;

查询视图

SELECT * FROM view_student;

删除视图(DROP VIEW 视图名)

DROP VIEW view_student;

在创建视图的SELECT语句中移除LIMIT子句

CREATE VIEW view_student AS
SELECT * FROM student;

在查询视图时使用LIMIT子句

SELECT * FROM view_student LIMIT 3;

自定义列名称

CREATE VIEW view_student_promo (id,name,gid) AS
SELECT sid,sname,gid FROM student;

查询视图

SELECT * FROM view_student_promo WHERE id <= 3;

在创建视图时,自定义列名称的顺序与AS后SELECT字段列表的顺序一致。

自定义列名称的数量必须与SELECT字段列表的数量一致。

多表操作

CREATE VIEW view_student_grade (sid,sname,gname) AS
SELECT sid,sname,g.name FROM student s
LEFT JOIN grade g ON s.gid=g.id;

查询视图

SELECT * FROM view_student_grade;

3.修改视图

修改视图:修改数据库中存在的视图的定义。

例如,当基本表中的某些字段发生变化时,视图必须修改才能正常使用。

修改已有视图

CREATE OR REPLACE VIEW view_student AS
SELECT sid,sname FROM student;

查询视图

SELECT * FROM view_student;

使用ALTER VIEW修改视图

ALTER VIEW view_student AS 
SELECT sname FROM student;

查询视图

SELECT * FROM view_student;

4.删除视图

语法

DROP VIEW [IF EXISTS] view_name [, view_name1] …

使用

DROP VIEW view_student;

删除多个

DROP VIEW view_student_grade,view_student_promo;

5.视图数据操作

创建视图

CREATE VIEW view_student AS
SELECT * FROM student;

插入数据

INSERT INTO view_student VALUES (9,'码海无际9',1);

如果遇到如下情况,操作可能会失败:

  1. 操作的视图定义在多个表上。

  2. 没有满足视图的基本表对字段的约束条件。

  3. 在定义视图的SELECT语句后的字段列表中使用了数学表达式或聚合函数。

  4. 在定义视图的SELECT语句中使用了DISTINCT、UNION、TOP、GROUP BY或HAVING子句。

修改数据

UPDATE view_student SET gid=2 WHERE sid=9;

删除数据

DELETE FROM view_student WHERE sid=9;

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值