mySQL 教程 第8章 视图
创建视图的目的
简单 隐藏数据复杂性
安全 可以对视图授权
数据独立 可以屏蔽表结构变化对用户的影响,比如增加列,更改列名
创建视图
1. 创建单表视图
以下视图显示JAVA班的学生姓名、身份证号和班级。
CREATE VIEW vJAVAstudent
as
SELECT sname 姓名,cardID 身份证号,class 班级 from `TStudent` where class='JAVA'
查询视图
select * from vJAVAstudent;

select 姓名,身份证号 from vJAVAstudent where 姓名='白安'

2. 在多表上创建视图
创建一个视图,展示学生学号 姓名 身份证号 班级 科目 成绩
create VIEW vStudentInfo
as
select a.studentid 学号,sname 姓名,cardID 身份证号,class 班级,subjectName 科目,mark 成绩 from `TStudent` a join `TScore` b on a.`StudentID`=b.`StudentID` join `TSubject` c on b.`subJectID`=c.`subJectID`
查询视图
select * from `vStudentInfo`

查找各科最高分
select 科目,MAX(成绩) 最高分 from `vStudentInfo` group by 科目

3. 创建视图
该视图显示学生学号 姓名 分数 和学科
CREATE VIEW `studentMark`
AS
(
SELECT a.studentid 学号,sname 姓名,mark 分数,subJectName 学科
FROM TStudent a JOIN TScore b ON a.studentid=b.studentid
JOIN TSubject c ON b.subjectid=c.subjectid
);
查询该视图
select * from studentMark

4. 行列转换视图
以以上视图为表,创建行列转换视图
CREATE VIEW Vmark
AS
(
SELECT 学号,姓名,
AVG(CASE 学科 WHEN '计算机网络' THEN 分数 END) 计算机网络,
AVG(CASE 学科 WHEN 'JAVA开发' THEN 分数 END) JAVA开发,
AVG(CASE 学科 WHEN '数据结构' THEN 分数 END) 数据结构
FROM `studentMark`
GROUP BY 学号
);
查询Vmark视图
select * from Vmark

查看视图
5. 查看视图基本信息
DESCRIBE `vStudentInfo`


如图,双击vStudentInfo视图,可以查看创建的视图

6. 在views表中查看视图详细信息
使用SQL admin 连接到Information_schema数据库
输入SELECT * FROM information_schema.views;


修改视图
1. 使用create or replace修改视图
给现有视图添加一列email
create OR REPLACE VIEW vStudentInfo
as
select a.studentid 学号,sname 姓名,cardID 身份证号,email 邮箱,class 班级,subjectName 科目,mark 成绩 from `TStudent` a join `TScore` b on a.`StudentID`=b.`StudentID` join `TSubject` c on b.`subJectID`=c.`subJectID`
2. 使用ALTER修改视图
给现有视图去掉身份证号列
ALTER VIEW vStudentInfo
as
select a.studentid 学号,sname 姓名,email 邮箱,class 班级,subjectName 科目,mark 成绩 from
`TStudent` a join `TScore` b on a.`StudentID`=b.`StudentID` join `TSubject` c on b.`subJectID`=c.`subJectID`
通过视图更改数据
通过视图来插入、更新、删除表中的数据,都是修改的基本表上进行更新
3. 通过视图更改数据
select * from `vStudentInfo`

给韩旭的数据结构加10分
update `vStudentInfo` set 成绩=成绩+10 where 姓名='韩旭' and 科目='数据结构'
查看结果
select * from `vStudentInfo`

4. 通过视图插入数据
下面视图能够插入数据
CREATE VIEW vJAVA
as
select studentID 学号,sname 姓名,sex 性别,email 邮箱,class 班级 from `TStudent` where class='JAVA'
通过视图插入记录
INSERT vJAVA values ('00025','姚帅','男','yaoshuai@onest.net','JAVA')
select * from vJAVA

5. 通过视图删除数据
delete from vJAVA where 学号='00025'
select * from vJAVA

删除创建的视图
6. 查看创建的视图

7. 删除视图
drop view `vJAVA`
按F5可以看到vJAVA视图已经被删除

8. 查看视图的语法

不能更新的视图
视图中不包含基表中被定义为非空的列
在定义视图的select语句后的字段列表中使用了数学表达式
在定义视图的select语句后的字段使用聚合函数
在定义视图的select语句中使用了distinct union top group by 或having
课下作业
创建一个视图 studentMark
select sname 姓名, subJectName 学科,mark 分数 from TStudent a join TScore b
on a.studentid=b.studentid join TSubject c on b.subjectid=c.subjectid
再创建一个视图Vmark,将studentMark进行行列转换
姓名 计算机网络 JAVA开发 数据结构
韩立刚 89 78 89
王瑞斯 90 78 76
mySQL 教程 第8章 视图的更多相关文章
- mySQL 教程 第7章 存储过程和函数
存储过程和存储函数 MySQL的存储过程(stored procedure)和函数(stored function)统称为stored routines. 1. MySQL存储过程和函数的区别 函数只 ...
- mySQL 教程 第4章 数据查询
mySQL运算符 这些运算符在SQL查询中用得到. 算数运算符 + 加 - 减 * 乘 / DIV 除 % MOD 取余数 比较运算符 = 等于 <> != 不等于 < <= ...
- mySQL 教程 第3章 数据类型和数据完整性
准备数据库 创建练习数据库,以下实验都是在这个数据库中完成. 练习1:比较各种数值型 create table tmp1 ( id INT, name VARCHAR(25), deptId deci ...
- mySQL 教程 第2章 安装和介绍mySQL
设置mySQL字符集 支持中文的字符集是utf8,该设置可以更改mySQL配置文件进行全局设置,也可以针对数据库设置,也可以针对表设置,也可以针对列设置.字符集更改后新插入的数据生效,对以前不生效. ...
- mySQL教程 第1章 数据库设计
E-R设计 很多同学在学SQL语句时,觉得非常困难,那是因为你在学一个你根本不了解的数据库,数据库中的表不是你设计的,表与表之间的关系你不明白.因此在学SQL语句之前,先介绍一下数据库设计. 下面举例 ...
- mySQL 教程 第5章 插入 更新与删除数据
使用SQL Manager管理工具连接到schoolDB.由于三张表都设置了主键,因此,以下练习中插入的记录,主键不能重. 插入数据 1. 练习:为表的所有字段插入数据 为表中所有字段插入数据,可以不 ...
- 转-MySQL教程-写的很详细,赞一个
原帖地址:https://www.w3cschool.cn/mysql/,谢谢原帖大人 MySQL是什么? MySQL安装 MySQL示例数据库 MySQL导入示例数据库 MySQL基础教程 MySQ ...
- 2017.2.16 开涛shiro教程-第十七章-OAuth2集成(一)服务器端
原博客地址:http://jinnianshilongnian.iteye.com/blog/2018398 根据下载的pdf学习. 开涛shiro教程-第十七章-OAuth2集成 1.OAuth2介 ...
- Cobalt Strike系列教程第七章:提权与横向移动
Cobalt Strike系列教程分享如约而至,新关注的小伙伴可以先回顾一下前面的内容: Cobalt Strike系列教程第一章:简介与安装 Cobalt Strike系列教程第二章:Beacon详 ...
随机推荐
- quartz---的一个简单例子
quartz---的一个简单例子 首先建立一个maven项目.jar工程即可.(提示:我前面有如何建立一个maven工程的总结以及maven环境的配置.) 1.建立好后点击到app中运行,--> ...
- Scrum介绍——续
四. Scrum过程 Scrum的过程如图4-1所示 图4-1 Scrum过程 4.1 建立Product Backlog Product Backlog是Product Owner把客户的商业需求按 ...
- linux make virtual memory more efficient three components
Page Cache This is used to speed up access to images and data on disk. As pages are read into memory ...
- mysql日期时间类型总结
MySQL 日期类型:日期格式.所占存储空间.日期范围 比较. 日期类型 存储空间 日期格式 日期范围 ------------ ---- ...
- hdu 1253 胜利大逃亡 (代码详解)解题报告
胜利大逃亡 Problem Description Ignatius被魔王抓走了,有一天魔王出差去了,这可是Ignatius逃亡的好机会. 魔王住在一个城堡里,城堡是一个A*B*C的立方体,可以被表示 ...
- C++内置类型的机器实现
大多数计算机以2的整数次幂个比特作为块来处理内存,可寻址的最小内存块称为“字节(byte)”,存储的基本单元称为“字(word)”,它通常有几个字节组成. 计算机以比特序列存储数据,即01000101 ...
- 【数据库】MFC ODBC(二)
三.CRecordset类 1.IsBOF与IsEOF (1)IsBOF 如果记录集没有记录,或已经向前游动到第一个记录之前,则返回非零:否则返回0.详细说明如下: 1)访问Open函数之后,如果记录 ...
- jenkins自动化打包部署
请参考: http://m.blog.csdn.net/article/details?id=50518959 1.启动 jenkins.war ,打开首页 192.168.158.129:8080 ...
- 【opencv基础】cv::Point类型与行列的关系
关系 row == height == Point.y col == width == Point.x Mat::at(Point(x, y)) == Mat::at(y,x) 参考 1.博客: 完
- 【linux基础】生成目录下所有图片的路径
command ls *.jpg > list.txt result .png .png .png .png .png command ls /home/xxx/input/*.png > ...