MySQL 视图的基础操作(五)_MySQL

1.为什么使用视图 
    为了提高复杂SQL语句的复用性和表操作的安全性(例如:工资字段不想展示给所有能查看该查询结果的人),MySQL提供了视图特性。所谓视图,本质上是一种虚拟表,其内容与真实的表相似,包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储数据值的形式存在。行和列的数据来自定义视图的查询所引用基本表,并且在具体使用视图时动态生成。 
视图有如下特点;
      1. 视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系。
      2. 视图是由基本表(实表)产生的表(虚表)。
      3. 视图的建立和删除不影响基本表。
      4. 对视图内容的更新(添加、删除和修改)直接影响基本表。
      5. 当视图来自多个基本表时,不允许添加和删除数据。

2.创建视图: 
在创建视图时,首先要确保拥有CREATE VIEW的权限,并且同时确保对创建视图所引用的表也具有相应的权限。 
2.1 创建视图的语法形式: 
    虽然视图可以被看成是一种虚拟表,但是其在物理上是不存在的,即数据库管理系统没有专门的位置为视图存储数据。根据视图的概念发现其数据来源于查询语句,因此创建视图的语法为:

CREATE VIEW view_name AS 查询语句
//说明:和创建表一样,视图名不能和表名、也不能和其他视图名重名。视图的功能实际就是封装了复杂的查询语句。

示例:

卡拉OK视频制作 卡拉OK视频制作

卡拉OK视频制作,在几分钟内制作出你的卡拉OK视频

卡拉OK视频制作 178 查看详情 卡拉OK视频制作

use zhaojd_test;  //选择一个自己创建的库create table t_product( //创建表  id int primary key,  pname varchar(20),  price decimal(8,2)); insert into t_product values(1,'apple',6.5); //向表中插入数据insert into t_product values(2,'orange',3); //向表中插入数据create view view_product as select id,name from t_product; //创建视图select * from view_product;

结果为:
+——+——–+
| id   | name   |
+——+——–+
| 1    | apple  |
| 2    | orange |
+——+——–+
//其实在创建视图时实际代码里写的是一个表查询语句,只不过把这个查询语句封装起来重新起了一个名字,方便可以重复使用。
//再者,安全性方面可以隐藏一些不希望看到的字段,比如这里的价格字段。
//注意:在SQL语句的命名规范中,视图一般以view_xxx或者v_xxx的样式来命名。视图的查询语句和表的查询语句相同。

2.2 创建各种视图: 
    由于视图的功能实际上时封装查询语句,那么是不是任何形式的查询语句都可以封装在视图中呢? 

2.2.1 封装实现查询常量语句的视图(常量视图):

示例:

mysql> create view view_test1 as select 3.1415926;Query OK, 0 rows affected (0.07 sec)mysql> select * from view_test1;+-----------+| 3.1415926 |+-----------+| 3.1415926 |+-----------+1 row in set (0.00 sec)

2.2.2 封装使用聚合函数(SUM、MIN、MAX、COUNT等)查询语句的视图:

示例:
首先准备需要用到的两张表及其初始化数据;

CREATE TABLE t_group(  id INT PRIMARY KEY AUTO_INCREMENT,  NAME VARCHAR(20));CREATE TABLE t_student(  id INT PRIMARY KEY AUTO_INCREMENT,  NAME VARCHAR(20),  sex CHAR(1),  group_id INT,  FOREIGN KEY (group_id) REFERENCES t_group (id));//t_group表中插入数据INSERT INTO t_group (NAME) VALUES('group_1');INSERT INTO t_group (NAME) VALUES('group_2');INSERT INTO t_group (NAME) VALUES('group_3');INSERT INTO t_group (NAME) VALUES('group_4');INSERT INTO t_group (NAME) VALUES('group_5');//t_student表中插入数据INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_1','M',1);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_2','M',1);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_3','M',2);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_4','W',2);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_5','W',2);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_6','W',2);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_7','M',3);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_8','W',4);INSERT INTO t_student (NAME,sex,group_id) VALUES('zjd_9','W',4);================================================================mysql> create view view_test2 as select count(name) from t_student;Query OK, 0 rows affected (0.71 sec)mysql> select * from view_test2;+-------------+| count(name) |+-------------+|      9 |+-------------+1 row in set (0.01 sec)

2.2.3 封装了实现排序功能(ORDER BY)查询语句的视图:

示例:

mysql> create view view_test3 as select name from t_student order by id desc;Query OK, 0 rows affected (0.06 sec)mysql> select * from view_test3;+-------+| name |+-------+| zjd_9 || zjd_8 || zjd_7 || zjd_6 || zjd_5 || zjd_4 || zjd_3 || zjd_2 || zjd_1 |+-------+9 rows in set (0.00 sec)

2.2.4 封装了实现表内连接查询语句的视图:

示例:(第二组学生的姓名)

mysql> create view view_test5 as select s.name from t_student s,t_group g where s.group_id=g.id and g.id=2;Query OK, 0 rows affected (0.07 sec)mysql> select * from view_test5;+-------+| name |+-------+| zjd_3 || zjd_4 || zjd_5 || zjd_6 |+-------+4 rows in set (0.00 sec)

2.2.5 封装了实现表外连接(LEFT JOIN和RIGHT JOIN)查询语句的视图:

示例:(第二组学生姓名)

mysql> create view view_test6 as select s.name from t_student s left join t_group g on s.group_id=g.id where g.id=2;Query OK, 0 rows affected (0.09 sec)mysql> select * from view_test6;+-------+| name |+-------+| zjd_3 || zjd_4 || zjd_5 || zjd_6 |+-------+4 rows in set (0.01 sec)

2.2.6 封装了实现子查询相关查询语句的视图:

示例:

mysql> create view view_test7 as select s.name from t_student s where s.id in(select id from t_group);Query OK, 0 rows affected (0.08 sec)mysql> select * from view_test7;+-------+| name |+-------+| zjd_1 || zjd_2 || zjd_3 || zjd_4 || zjd_5 |+-------+5 rows in set (0.00 sec)

2.2.7 封装了实现记录联合(UNION和UNION ALL)查询语句的视图:

mysql> create view view_test8 as select id,name from t_student union all select id,name from t_group;Query OK, 0 rows affected (0.08 sec)mysql> select * from view_test8;+----+---------+| id | name  |+----+---------+| 1 | zjd_1  || 2 | zjd_2  || 3 | zjd_3  || 4 | zjd_4  || 5 | zjd_5  || 6 | zjd_6  || 7 | zjd_7  || 8 | zjd_8  || 9 | zjd_9  || 1 | group_1 || 2 | group_2 || 3 | group_3 || 4 | group_4 || 5 | group_5 |+----+---------+14 rows in set (0.01 sec)

3.查看视图: 
3.1 SHOW TABLES语句查看视图名: 
执行SHOW TABLES 语句时不仅可以显示表的名字,同时也是显示出视图的名字。

示例:

mysql> show tables;+------------------+| Tables_in_zhaojd |+------------------+| t_group     || t_product    || t_student    || v_product    || view_test1    || view_test2    || view_test3    || view_test4    || view_test5    || view_test6    || view_test8    |+------------------+11 rows in set (0.00 sec)

 3.2 SHOW TABLE STATUS语句查看视图详细信息: 

和SHOW TABLES语句一样,SHOW TABLE STATUS语句不仅会显示表的详细信息,同时也会显示视图的详细信息。

语法如下:
SHOW TABLE STATUS [FROM db_name] [LIKE ‘pattern’]
//参数db_name用来设置数据库,SHOW TABLES STATUS表示将显示所设置库的表和视图的详细信息。
//设置LIKE关键字,可以查看某一个具体表或视图的详细信息。例如: SHOW TABLE STATUS FROM zhaojd LIKE ‘t_group’ G
示例:

mysql> show table status from zhaojd G*************************** 1. row ***************************      Name: t_group     Engine: InnoDB    Version: 10   Row_format: Compact      Rows: 5 Avg_row_length: 3276  Data_length: 16384Max_data_length: 0  Index_length: 0   Data_free: 7340032 Auto_increment: 6  Create_time: 2016-08-19 16:26:06  Update_time: NULL   Check_time: NULL   Collation: utf8_general_ci    Checksum: NULL Create_options:    Comment:=============================================================       Name: view_test8     Engine: NULL    Version: NULL   Row_format: NULL      Rows: NULL Avg_row_length: NULL  Data_length: NULLMax_data_length: NULL  Index_length: NULL   Data_free: NULL Auto_increment: NULL  Create_time: NULL  Update_time: NULL   Check_time: NULL   Collation: NULL    Checksum: NULL Create_options: NULL    Comment: VIEW

3.3 SHOW CREATE VIEW语句查看视图定义信息:

语法为:
 SHOW CREATE VIEW viewname;
 示例:

 mysql> show create view view_test8 G*************************** 1. row ***************************View: view_test8Create View: CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `view_test8` AS select `t_student`.`id` AS `id`,`t_student`.`NAME` AS `name` from `t_student` union all select `t_group`.`id` AS `id`,`t_group`.`NAME` AS `name` from `t_group`character_set_client: utf8collation_connection: utf8_general_ci1 row in set (0.00 sec)//根据执行结果可以发现,SHOW CREATE VIEW语句返回两个字段,分别为表示视图名的View字段和关于视图定义的Create view字段。

3.4 DESCRIBE | DESC 语句查看视图定义信息:

语法为:
 DESCRIBE | DESC viewname;
示例:

mysql> desc view_test8;+-------+-------------+------+-----+---------+-------+| Field | Type    | Null | Key | Default | Extra |+-------+-------------+------+-----+---------+-------+| id  | int(11)   | NO  |   | 0    |    || name | varchar(20) | YES |   | NULL  |    |+-------+-------------+------+-----+---------+-------+2 rows in set (0.02 sec) 

3.5 通过系统表查看视图信息: 
当MySQL安装成功后,会自动创建系统数据库infomation_schema。在该数据库中存在一个包含视图信息的表格,可以通过查看表格views来查看所有视图的相关信息。

示例:

mysql> use information_schema;Database changedmysql> select * from views where table_name='view_test8' G*************************** 1. row ***************************    TABLE_CATALOG: def    TABLE_SCHEMA: zhaojd     TABLE_NAME: view_test8   VIEW_DEFINITION: select `zhaojd`.`t_student`.`id`AS`id`,`zhaojd`.`t_student`.`NAME` AS `name` from `zhaojd`.`t_student` union all select `zhaojd`.`t_group`.`id` AS`id`,`zhaojd`.`t_group`.`NAME` AS `name` from `zhaojd`.`t_group`    CHECK_OPTION: NONE    IS_UPDATABLE: NO       DEFINER: root@localhost    SECURITY_TYPE: DEFINERCHARACTER_SET_CLIENT: utf8COLLATION_CONNECTION: utf8_general_ci1 row in set (0.01 sec)

4.删除视图: 
在删除视图时首先要确保拥有删除视图的权限。

语法为:
DROP VIEW view_name [,view_name] ……
//从语法可以看出,DROP VIEW一次可以删除多个视图
示例:

mysql> use zhaojd;Database changedmysql> show tables;+------------------+| Tables_in_zhaojd |+------------------+| t_group     || t_product    || t_student    || v_product    || view_test1    || view_test2    || view_test3    || view_test4    || view_test5    || view_test6    || view_test8    |+------------------+11 rows in set (0.00 sec)mysql> drop view view_test1, view_test2;Query OK, 0 rows affected (0.01 sec)mysql> show tables;+------------------+| Tables_in_zhaojd |+------------------+| t_group     || t_product    || t_student    || v_product    || view_test3    || view_test4    || view_test5    || view_test6    || view_test8    |+------------------+9 rows in set (0.00 sec)

5.修改视图: 
5.1 CREATE OR REPLACE VIEW语句修改视图: 
对于已经创建好的表,尤其是已经有大量数据的表,通过先删除,然后再按照新的表定义重新建表的方式来修改表,需要做很多额外的工作,例如数据的重载等。可是对于视图来说,由于是“虚表”,并没有存储数据,所以完全可以通过该方式来修改视图。

实现思路就是:先删除同名的视图,然后再根据新的需求创建新的视图即可。

DROP VIEW view_name; CREATE VIEW view_name as 查询语句;

但是如果每次修改视图,都是先删除视图,然后再次创建一个同名的视图,则显得非常麻烦。于是MySQL提供了更方便的实现替换的创建视图的语法,完整语法为:

CREATE OR REPLACE VIEW view_name as 查询语句;

 5.2 ALTER语句修改视图:

语法为:

ALTER VIEW view_name as 查询语句;

6.利用视图操作基本表: 
再MySQL中可以通常视图检索基本表数据,这是视图最基本的应用,除此之后还可以通过视图修改基本表中的数据。 
6.1检索(查询)数据: 
    通过视图查询数据,与通过表进行查询完全相同,只不过通过视图查询表更安全,更简单实用。只需要把表名换成视图名即可。 
6.2利用视图操作基本表数据: 
    由于视图是“虚表”,所以对视图数据进行的更新操作,实际上是对其基本表数据进行的更新操作。在具体更新视图数据时,需要注意以下两点;
    1. 对视图数据进行添加、删除直接影响基本表。
    2. 视图来自于多个基本表时,不允许添加、删除数据。
    视图中的添加数据操作、删除数据操作、更新数据操作的语法同表完全相同。只是将表名换成视图名即可。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/426680.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 12:01:00
下一篇 2025年11月7日 12:05:34

相关推荐

  • PHP/MySQL预约时间冲突检测与处理教程

    本文详细讲解如何在php应用中高效准确地检测预约时间冲突。通过构建包含时间段重叠逻辑的sql查询,并结合pdo进行参数绑定和结果判断,确保新提交的预约不会与现有预约发生冲突。教程涵盖核心sql逻辑、php实现代码、以及关键的注意事项,旨在帮助开发者构建健壮的预约系统。 在开发涉及时间安排或资源预定的…

    2025年12月12日
    000
  • PHP预约系统:实现高效时间冲突检测

    本文详细介绍了在PHP中实现预约时间冲突检测的专业方法。通过优化SQL查询,利用数据库层面的`COUNT(*)`函数和精确的时间区间重叠逻辑,避免了低效的PHP端循环检测,确保了预约系统的准确性和性能。教程涵盖了时间重叠的判断条件、SQL查询构建、PDO参数绑定以及完整的PHP示例代码,旨在帮助开发…

    2025年12月12日
    000
  • PHP匿名函数变量传递机制:参数、use关键字与作用域解析

    本文深入探讨php匿名函数中变量传递的三种主要机制:通过函数参数直接传递值、利用`use`关键字从父作用域继承变量,以及参数与外部变量同名时的作用域遮蔽效应。通过实例代码,清晰阐释了它们的工作原理、适用场景及注意事项,旨在帮助开发者准确理解和高效运用匿名函数。 PHP匿名函数,也常被称为闭包(Clo…

    2025年12月12日
    000
  • PHP同一页面实现多条表单提交不覆盖的技巧

    本文详细介绍了如何在php中实现同一页面多次提交表单而不覆盖先前数据的方法。通过利用html表单的数组命名机制(`name=”field[]”`)和动态生成隐藏输入框,确保每次提交都能累积并显示所有历史数据,从而实现“无限”次提交并展示记录的功能。 在Web开发中,当用户在同…

    2025年12月12日
    000
  • php怎么安装_如何在Linux服务器上部署PHP环境

    答案是Nginx + PHP-FPM组合更适合现代PHP应用部署。首先更新系统,安装PHP-FPM及常用扩展,并配置Nginx通过FastCGI与PHP-FPM通信,实现高效、安全的请求处理。相比Apache的mod_php,Nginx+PHP-FPM具备更好的性能、资源隔离和高并发支持。同时需注意…

    2025年12月12日
    000
  • PHP预约系统时间冲突检测:高效与安全的实现方法

    本文旨在提供一个php预约系统如何高效、准确地检测医生预约时间冲突的教程。我们将分析常见错误,并详细讲解如何利用sql的`count(*)`和精心设计的`where`子句来判断新预约是否与现有预约重叠,确保预约系统的稳定性和数据一致性。 引言:预约系统中的时间冲突检测 在开发任何预约或排班系统时,核…

    2025年12月12日
    000
  • 使用预处理语句和 IN 子句查询 MySQL 时只返回第一行的问题

    本文旨在解决在使用 MySQL 预处理语句和 `IN` 子句时,当使用字符串绑定作为 `WHERE IN` 的条件时,只返回第一行数据的问题。我们将分析问题原因,并提供避免此问题的解决方案,包括规范化数据库表结构等方法。 在使用 MySQL 预处理语句结合 IN 子句进行查询时,可能会遇到一个常见的…

    好文分享 2025年12月12日
    000
  • php调用数据库迁移工具_php调用Phinx管理数据库版本

    Phinx是PHP数据库迁移工具,通过Composer安装并生成配置文件,支持多环境管理;创建迁移文件定义up/down方法,执行migrate命令更新数据库结构;可在PHP代码中调用API自动化运行迁移,适用于CI/CD流程;常用命令包括创建、执行、回滚迁移及管理种子数据,实现数据库版本的可追踪与…

    2025年12月12日
    000
  • php新手怎么找工作_PHP新手求职方向、平台选择与实战建议

    答案是通过项目证明能力并主动拓展求职渠道。先做PHP+MySQL项目如商城后台,发布到GitHub并写好README;再从小公司需求、技术社区、开源项目中找机会;面试时重点准备PHP基础、MySQL操作和项目讲解,突出解决问题的能力。 刚学完PHP怎么找工作?这是很多新手都会问的问题。答案其实不复杂…

    2025年12月12日
    000
  • php数据如何优化数据库查询性能_php数据SQL语句索引优化指南

    答案:优化PHP数据库性能需合理设计索引、避免全表扫描、使用执行计划分析及代码层优化。应为常用查询字段建索引,遵循最左匹配原则,避免低选择性字段单独建索引;SQL语句中避免函数操作、SELECT * 和前导LIKE,减少IN列表长度;通过EXPLAIN分析执行计划,确保使用索引并降低扫描行数;PHP…

    2025年12月12日
    000
  • php数据库如何使用视图 php数据库虚拟表的创建与优势

    在PHP开发中,与数据库交互是常见需求。为了提升查询效率、简化复杂操作并增强数据安全性,使用数据库视图(View)是一种非常有效的手段。视图本质上是一个“虚拟表”,它并不实际存储数据,而是基于SQL查询动态生成结果。 什么是数据库视图 视图是基于一个或多个数据表的查询结果构建的虚拟表。它没有独立的数…

    2025年12月12日
    000
  • php数据如何使用PDO扩展进行数据库操作_php数据抽象层PDO的用法详解

    PDO提供统一接口操作多种数据库,支持预处理和事务。1. 创建PDO实例连接数据库并设置异常模式;2. 用query或prepare执行查询,推荐预处理防SQL注入;3. 增删改用prepare+execute更安全;4. 通过beginTransaction、commit、rollback实现事务…

    2025年12月12日
    000
  • SQL库存优化策略:按过期日期和数量筛选最佳库存记录

    本教程深入探讨如何通过sql查询优化库存选择,优先考虑最早过期日期并结合可用数量限制。我们将展示如何利用`order by`和`limit`子句高效地从库存数据中筛选出符合特定需求的最佳记录,避免常见的查询陷阱,并提升数据检索的准确性与效率。 第一章:理解库存筛选的核心需求 在库存管理场景中,我们经…

    2025年12月12日
    000
  • PHP mysqli 数据库连接错误排查与最佳实践

    本文旨在深入探讨php `mysqli` 数据库连接中常见的“could not connect”错误,并提供一套系统的排查方法与最佳实践。我们将详细解析`mysqli`构造函数的参数,区分主机名与端口的正确指定方式,并给出标准化的连接代码示例,帮助开发者有效诊断并解决数据库连接问题,确保应用程序与…

    2025年12月12日
    000
  • PHP代码怎么处理表单提交数据_PHP表单数据接收与验证处理步骤

    答案:PHP处理表单需接收、验证和安全处理数据。首先通过$_POST获取数据,使用empty()、filter_var()等函数验证必填项与格式,再用htmlspecialchars()防XSS,预处理语句防SQL注入,password_hash()加密密码,最后重定向防重复提交。 处理表单提交数据…

    2025年12月12日
    000
  • PHP mysqli 连接故障排除:正确理解与使用连接参数

    本文深入探讨了php中使用`mysqli`扩展连接mysql数据库时常见的连接失败问题。重点解析`mysqli`构造函数中的主机名、用户名、密码、数据库名及端口号等关键参数的正确用法,并提供详细的示例代码和故障排除策略,帮助开发者有效解决数据库连接障碍,确保应用稳定运行。 在PHP开发中,mysql…

    2025年12月12日
    000
  • PHP 后台进程控制与定时任务调度:使用 Cron Jobs 实现动态配置响应

    本文将深入探讨如何利用 PHP 脚本结合 Cron Jobs 实现后台任务的调度与动态配置响应。我们将介绍 Cron Jobs 的基本原理、配置方法,并演示如何通过持久化存储在 Web 请求与定时任务间传递参数,从而实现后台逻辑的灵活调整。同时,文章也将指出 Cron Jobs 在高频实时控制场景下…

    2025年12月12日
    000
  • 如何让PHP持久化脚本“忘记”一切并实现类似重启的效果

    本文探讨了在PHP持久化脚本中,如何在不进行物理重启的情况下,模拟“重置”脚本内部状态和加载新代码的挑战与策略。由于PHP的运行机制限制,直接“卸载”函数和类是不可能的。文章提供了通过变量管理、对象封装与重新实例化、外部配置加载,以及利用pcntl_exec()进行进程替换等多种方法,以帮助开发者在…

    2025年12月12日
    000
  • linux php怎么运行环境_linux下搭建PHP运行环境的详细教程

    首先安装Web服务器(如Apache),在Ubuntu上使用apt install apache2,在CentOS上使用yum install httpd,启动并设置开机自启后,通过访问IP验证运行状态;接着安装PHP 8.1,Ubuntu需添加ondrej/php PPA仓库,CentOS需启用R…

    2025年12月12日
    000
  • 实现Laravel模型及其关联关系的部分字符串搜索

    本文介绍了如何在 Laravel 中实现对模型及其一对多关联关系中的部分字符串搜索。通过 whereHas() 方法,可以轻松地在关联模型的字段中查找包含特定字符串的记录,从而实现更强大的搜索功能。文章提供了详细的代码示例,帮助开发者快速理解和应用。 在实际应用中,经常需要根据用户输入的关键词,在数…

    2025年12月12日
    000

发表回复

登录后才能评论
关注微信