- 1、本文档共18页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
PAGE1
PAGE1
MySQL视图基础
1视图的概念与作用
视图在MySQL中是一种虚拟表,它并不存储数据,而是存储一个SQL查询语句。这个查询语句可以基于一个或多个实际存在的表,通过这个查询,视图可以展示出与实际表不同的数据视图。视图的主要作用包括:
简化查询:通过创建视图,可以将复杂的查询语句封装起来,简化用户的查询操作。
数据安全:视图可以限制用户只能看到和访问特定的数据,而不能访问底层的全部数据,从而实现数据的安全隔离。
数据整合:视图可以将多个表的数据整合在一起,提供一个统一的查询接口,使得数据的查询和使用更加方便。
1.1示例:创建视图
假设我们有一个students表和一个courses表,students表包含学生信息,courses表包含课程信息。我们想要创建一个视图,展示每个学生所选课程的信息。
--创建students表
CREATETABLEstudents(
idINTAUTO_INCREMENTPRIMARYKEY,
nameVARCHAR(50),
ageINT
);
--创建courses表
CREATETABLEcourses(
idINTAUTO_INCREMENTPRIMARYKEY,
nameVARCHAR(50),
student_idINT,
FOREIGNKEY(student_id)REFERENCESstudents(id)
);
--插入数据
INSERTINTOstudents(name,age)VALUES(张三,20),(李四,22);
INSERTINTOcourses(name,student_id)VALUES(数学,1),(英语,1),(物理,2);
--创建视图
CREATEVIEWstudent_coursesAS
SELECTs.nameASstudent_name,c.nameAScourse_name
FROMstudentss
JOINcoursescONs.id=c.student_id;
通过这个视图,我们可以直接查询学生和他们所选的课程,而不需要了解底层的表结构和关联方式。
2创建视图的基本语法
创建视图的基本语法如下:
CREATEVIEWview_nameAS
SELECTcolumn1,column2,...
FROMtable_name
WHEREcondition;
view_name:视图的名称。
SELECT:定义视图的查询语句。
FROM:指定查询的表。
WHERE:可选,用于添加查询条件。
2.1示例:创建基于条件的视图
假设我们有一个employees表,包含员工信息,我们想要创建一个视图,只展示工资高于5000的员工信息。
--创建employees表
CREATETABLEemployees(
idINTAUTO_INCREMENTPRIMARYKEY,
nameVARCHAR(50),
salaryDECIMAL(10,2)
);
--插入数据
INSERTINTOemployees(name,salary)VALUES(王五,5500),(赵六,4500);
--创建视图
CREATEVIEWhigh_salary_employeesAS
SELECT*
FROMemployees
WHEREsalary5000;
通过这个视图,我们可以直接查询工资高于5000的员工信息,而不需要每次都添加WHEREsalary5000的条件。
3修改与删除视图
修改视图实际上就是重新定义视图的查询语句,而删除视图则是将视图从数据库中完全移除。
3.1修改视图
修改视图的语法如下:
ALTERVIEWview_nameAS
SELECTcolumn1,column2,...
FROMtable_name
WHEREcondition;
3.2示例:修改视图
假设我们之前创建的student_courses视图,现在我们想要修改它,只展示年龄大于20的学生所选的课程。
ALTERVIEWstudent_coursesAS
SELECTs.nameASstudent_name,c.nameAScourse_name
FROMstudentss
JOINcoursescONs.id=c.student_id
WHEREs.age20;
3.3删除视图
删除
您可能关注的文档
- 后端开发工程师-数据库管理-MySQL_MySQL高级特性.docx
- 后端开发工程师-数据库管理-MySQL_MySQL基础概念与安装.docx
- 后端开发工程师-数据库管理-MySQL_SQL语言基础.docx
- 后端开发工程师-数据库管理-MySQL_连接查询与子查询.docx
- 后端开发工程师-数据库管理-MySQL_事务处理与锁机制.docx
- 后端开发工程师-数据库管理-MySQL_数据查询与筛选.docx
- 后端开发工程师-数据库管理-MySQL_数据库迁移与数据导入导出.docx
- 后端开发工程师-数据库管理-MySQL_数据库索引与优化.docx
- 后端开发工程师-数据库管理-MySQL_数据库性能监控与调优.docx
- 后端开发工程师-数据库管理-NoSQL_NoSQL简介与特点.docx
最近下载
- 工具保养指南.pdf VIP
- 2019-2020中国入境游游客行为与态度研究报告.pptx
- 家禽生产学题库.docx VIP
- DS160美国签证申请表(中文版).docx VIP
- 第六单元 基层治理与社会保障 单元练习 高二历史统编版2019选择性必修1+国家制度与社会治理.docx VIP
- 富士达电梯UCMP测试说明.pdf
- 【2023部编高教版】中职历史 基础模块 中国历史 第五课秦汉时期的经济、科技与文化 (教案).docx VIP
- 癌痛理论考试测试卷附答案.doc
- 第六单元基层治理与社会保障知识清单高二历史(选择性必修1国家制度与社会治理).docx VIP
- 【2023部编高教版】中职历史 基础模块 中国历史 第十二课 明朝的兴亡 (教案).docx VIP
文档评论(0)