首页 数据库 mysql教程 MySQL(基础篇)之视图

MySQL(基础篇)之视图

Jun 07, 2016 pm 03:03 PM
mysql 什么 优点 作用 基础 简介 视图

一: 视图的简介,作用,优点 1. 什么是视图? a. 视图是一种虚拟的表 ,是从数据库中一个或者多个表中导出的表 b. 数据库只存放了视图的定义,而并没有存放视图中的数据, 这些数据存放在原来的表中 c. 使用视图查询数据时,数据库系统会从原来的表中取出对应的记录



一: 视图的简介,作用,优点

1.       什么是视图?

a.       视图是一种虚拟的表,是从数据库中一个或者多个表中导出的表

b.       数据库只存放了视图的定义,而并没有存放视图中的数据,这些数据存放在原来的表中

c. 使用视图查询数据时,数据库系统会从原来的表中取出对应的记录

 

2.         视图的作用:

a.         使操作简便化

b.         增加数据的安全性

c.         提高表的逻辑独立性


3.         视图的优点:

a. 视点集中

b. 简化操作

c. 定制数据

d. 合并分割数据

· e. 安全性

 

二: 创建视图

CREATE [ ALGORITHM ={ UNDEFIEND | MERGE | TEMPTABLE }]

VIEW 视图名[ ( 属性清单) ]

AS SELECT 语句

[ WITH [ CASCADED | LOCAL ] CHECK OPTION ];

 

ALGORITHM 是可选参数,表示视图选择的算法;

“视图名”参数表示要创建的视图的名称;

“属性清单”是可选参数,其指定了视图中各种属性的名词,默认情况下与SELECT 语句中查询的属性相同;

SELECT 语句参数是一个完整的查询语句,标识从某个表查出某些满足条件的记录,将这些记录导入视图中;

WITH CHECK OPTION 是可选参数,表似乎更新视图时要保证在该视图的权限范围之内;

ALGORITHM 包括3 个选项UNDEFINED、MERGE 和TEMPTABLE。

UNDEFINED 选项表示MySQL 将自动选择所要使用的算法;

MERGE 选项表示将使用视图的语句与视图定义合并起来,使得视图定义的某一部分取代语句的对应部分;

TEMPTABLE 选项表示将视图的结果存入临时表,然后使用临时表执行语句;CASCADED是可选参数,表示更新视图时要满足所有相关视图和表的条件,该参数为默认值;

LOCAL 表示更新视图时,要满足该视图本身的定义条件即可;

 

例: 创建一个名为v1的视图,其中包含了t_book表的全部记录

Mysql>CREATE VIEW v1

AS

SELECT * FROM t_book;

接下来我们就可以对这个视图进行操作,查询视图中id为2的记录

Mysql>SELECT * FROM v1 WHERE id=2;

例: 创建一个名为v2的视图,其中只显示书名和价格信息

Mysql>CREATE VIEW v2

AS

SELECT bookName,price FROM t_book;

Mysql>SELECT * FROM v2;

现在v2视图中就只包含书名和价格的信息

 

例: 这样写的话,你会发现字段名变成了书名和价格

Mysql>CREATE VIEW v3(书名,价格)

AS

SELECT bookName,price FROM t_book;

Mysql>SELECT * FROM v2;

 

当然,也可以这么写:

Mysql>CREATE VIEW v4

AS

SELECT bookName AS '书名',price AS '价格' FROM t_book;

 

例: 根据t_book和t_booktype表建立视图,查询书名和书的类别

Mysql>CREATE VIEW v5

AS

SELECT bookName,bookTypeName FROM t_book t1,t_booktype t2 WHERE t1.bookTypeId=t2.id;

 

三:查看视图

4.1 DESCRIBE 语句查看视图基本信息

例: 查看v4视图的基本信息

Mysql>DESC v4;

 

4.2 SHOW TABLE STATUS LIKE 语句查看视图基本信息

例: 查看v5视图的基本信息

Mysql>SHOW TABLE STATUS LIKE 'v5';

可以很明显的看出 视图是虚表

4.3 SHOW CREATE VIEW 语句查看视图详细信息

例: 查看v5视图的详细信息

Mysql>SHOW CREATE VIEW v5;

 

4.3 在views 表中查看视图详细信息

Mysql>USE information_schema;

Mysql>SELECT * FROM views;

这样 我们就能看到所有已经创建的视图的信息

 

四: 修改视图

4.1 CREATE OR REPLACE VIEW 语句修改视图

CREATE OR REPLACE [ ALGORITHM ={ UNDEFINED | MERGE | TEMPTABLE }]

VIEW 视图名[( 属性清单)]

AS SELECT 语句

[ WITH [ CASCADED | LOCAL ] CHECK OPTION ];

如果视图存在就REPLACE该视图,如果不存在 就Create 该视图

 

例: Mysql>CREATE OR REPLACE VIEW v3

AS

SELECT * FROM t_book WHERE id =3;

 

4.2 ALTER 语句修改视图

ALTER [ ALGORITHM ={ UNDEFINED | MERGE | TEMPTABLE }]

VIEW 视图名[( 属性清单)]

AS SELECT 语句

[ WITH [ CASCADED | LOCAL ] CHECK OPTION ];

只能修改视图,不能创建视图

例: Mysql>ALTER VIEW v3

AS

SELECT * FROM t_book;

 

五: 更新视图

更新视图是指通过视图来插入(INSERT)、更新(UPDATE)和删除(DELETE)表中的数据。因为视图是一个虚拟的表,其中没有数据。通过视图更新时,都是转换基本表来更新。更新视图时,只能更新权限范围内的数据。超出了范围,就不能更新。

 

5.1 插入(INSERT)

例: Mysql>INSERT INTO v4 VALUES(NULL,'心理学',45,'三张',4);

 

5.2 更新(UPDATE)

例: Mysql>UPDATE v4 SET bookName='心理学2' WHERE id =5;

5.3 删除(DELETE)

Mysql>DELETE FROM v4 WHERE id =5;

通过视图来插入(INSERT)、更新(UPDATE)和删除(DELETE)时,都是对原表来进行操作.

 

六: 删除视图

删除视图是指删除数据库中已存在的视图。删除视图时,只能删除视图的定义,不会删除数据;

DROP VIEW [ IF EXISTS ] 视图名列表[ RESTRICT | CASCADE ]

例: 如果存在名为v4的视图,那么就删除.

Mysql>DROP VIEW IF EXISTS v4;

 

七: 总结

视图到这就结束了,大家好好消化下视图,下节将为大家带来触发器的使用,谢谢大家!MySQL(基础篇)之视图

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1666
14
CakePHP 教程
1425
52
Laravel 教程
1327
25
PHP教程
1273
29
C# 教程
1252
24
laravel入门实例 laravel入门实例 Apr 18, 2025 pm 12:45 PM

Laravel 是一款 PHP 框架,用于轻松构建 Web 应用程序。它提供一系列强大的功能,包括:安装: 使用 Composer 全局安装 Laravel CLI,并在项目目录中创建应用程序。路由: 在 routes/web.php 中定义 URL 和处理函数之间的关系。视图: 在 resources/views 中创建视图以呈现应用程序的界面。数据库集成: 提供与 MySQL 等数据库的开箱即用集成,并使用迁移来创建和修改表。模型和控制器: 模型表示数据库实体,控制器处理 HTTP 请求。

MySQL和PhpMyAdmin:核心功能和功能 MySQL和PhpMyAdmin:核心功能和功能 Apr 22, 2025 am 12:12 AM

MySQL和phpMyAdmin是强大的数据库管理工具。1)MySQL用于创建数据库和表、执行DML和SQL查询。2)phpMyAdmin提供直观界面进行数据库管理、表结构管理、数据操作和用户权限管理。

MySQL与其他编程语言:一种比较 MySQL与其他编程语言:一种比较 Apr 19, 2025 am 12:22 AM

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

解决数据库连接问题:使用minii/db库的实际案例 解决数据库连接问题:使用minii/db库的实际案例 Apr 18, 2025 am 07:09 AM

在开发一个小型应用时,我遇到了一个棘手的问题:需要快速集成一个轻量级的数据库操作库。尝试了多个库后,我发现它们要么功能过多,要么兼容性不佳。最终,我找到了minii/db,这是一个基于Yii2的简化版本,完美地解决了我的问题。

laravel框架安装方法 laravel框架安装方法 Apr 18, 2025 pm 12:54 PM

文章摘要:本文提供了详细分步说明,指导读者如何轻松安装 Laravel 框架。Laravel 是一个功能强大的 PHP 框架,它 упростил 和加快了 web 应用程序的开发过程。本教程涵盖了从系统要求到配置数据库和设置路由等各个方面的安装过程。通过遵循这些步骤,读者可以快速高效地为他们的 Laravel 项目打下坚实的基础。

解决MySQL模式问题:TheliaMySQLModesChecker模块的使用体验 解决MySQL模式问题:TheliaMySQLModesChecker模块的使用体验 Apr 18, 2025 am 08:42 AM

在使用Thelia开发电商网站时,我遇到了一个棘手的问题:MySQL模式设置不当,导致某些功能无法正常运行。经过一番探索,我找到了一个名为TheliaMySQLModesChecker的模块,它能够自动修复Thelia所需的MySQL模式,彻底解决了我的困扰。

MySQL:结构化数据和关系数据库 MySQL:结构化数据和关系数据库 Apr 18, 2025 am 12:22 AM

MySQL通过表结构和SQL查询高效管理结构化数据,并通过外键实现表间关系。1.创建表时定义数据格式和类型。2.使用外键建立表间关系。3.通过索引和查询优化提高性能。4.定期备份和监控数据库确保数据安全和性能优化。

MySQL:解释的关键功能和功能 MySQL:解释的关键功能和功能 Apr 18, 2025 am 12:17 AM

MySQL是一个开源的关系型数据库管理系统,广泛应用于Web开发。它的关键特性包括:1.支持多种存储引擎,如InnoDB和MyISAM,适用于不同场景;2.提供主从复制功能,利于负载均衡和数据备份;3.通过查询优化和索引使用提高查询效率。

See all articles