【Mysql】mysql学习之旅07-视图

mysql学习之旅07-视图

定义:是对现有表的一种投影,是一个虚拟的表,可以按照表的操作来操作试图

  1. 简化代码,提高sql语句的可读性
  2. 隐藏先有的表结构,提高数据库的安全性
  3. 通过对视图的操作,可以映射到对表的操作
  4. 视图一般主要用于统计查询,也可以进行CRUD.
语法:
  1. 创建视图
CREATE VIEW 视图名 AS 单表查询/多表查询/子查询
  1. 修改视图
ALTER VIEW 视图名 AS 单表查询/多表查询/子查询
  1. 删除视图
DROP VIEW 视图名;
  1. 查看视图
SHOW CREATE VIEW 视图名

注意:

  1. 如果使用单表查询创建视图,视图和原表一样可以进行CURD操作,数据和原表同步
  2. 如果使用多表查询创建视图,若使用外连接进行多表查询,视图无法进行数据库的操作。
sql操作:
//查询创建表
CREATE TABLE boys_table AS 
SELECT * FROM sutdent WHERE sex = 1;

//修改视图
alter view boys_view as
select id,stu_num,`name`,classes_id from student
where sex = 1;

//删除视图
drop view boys_view;

//多表查询的视图
create view student_classes_view as
select
student.*, classes.`name` as classes_name
from
student left join  classes
on
student.classes_id = classes.id

create view teacher_classes_view as
select
classes.*, teacher.`name` as teacher_name
from
teacher left join classes
on teacher.id = classes.teacher_id;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JeffHan^_^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值