mysql 视图调用存储过程_mysql--视图,触发器,事务,存储过程

一.视图

视图是一个虚拟表(非真实存在),是跑到内存中的表,真实表是硬盘上的表,怎么就得到了虚拟表,就是你查询的结果,只不过之前我们查询出来的虚拟表,从内存中取出来显示在屏幕上,内存中就没有了这些表的数据,但是下次我要是想用这个虚拟表呢,没办法,只能重新查一次,每次都要重新查。其本质是【根据SQL语句获取动态的数据集,并为其命名】,用户使用时只需使用【名称】即可获取结果集,可以将该结果集当做表来使用。如果我们想查询一些有关联的表,比如我们前面的老师学生班级什么的表,我可能需要几个表联合查询的结果,但是这几张表在硬盘上是单独存的,所以我们需要通过查询的手段,将这些表在内存中拼成一个虚拟表,然后是不是我们再基于虚拟表在进行进一步的查询,然后我们如果以后想重新再查一下这些关系数据,还需要对硬盘上这些表进行再次的重新加载到内容,联合成虚拟表,然后再筛选等等的操作,意味着咱们每次都在写重复的sql语句,那有没有好的方法啊,其实很简单,我们把重复用的这些sql逻辑封装起来,然后下次使用的时候直接调用这个封装好的操作就可以了,这个封装起来的操作就类似我们下面要说的视图

为什么要用视图:使用视图我们可以把查询过程中的临时表摘出来,保存下来,用视图去实现,这样以后再想操作该临时表的数据时就无需重写复杂的sql了,直接去视图中查找即可,但视图有明显地效率问题,并且视图是存放在数据库中的,如果我们程序中使用的sql过分依赖数据库中的视图,即强耦合,那就意味着扩展sql极为不便,因此并不推荐使用

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

视图是一个虚拟表,在视图中用户可以使用select语句查询数据,以及使用insert,update,和delete修改记录,从myql5.0开始可以使用视图,视图可以使用户操作方便,而且可以保障数据库系统的安全,视图一经定义便存储在数据库中,与其相对应的数据并没有像表那样在数据库中再存储一份,通过视图可以看到的数据只是存放在基本表中的数据

视图的概述

视图的数据修改时,基本表的数据也会修改.同时,若基本表的数据发生变化,视图中的数据也发生变化

基本语句

一.创建视图create view 视图名称 asSQL语句;

二.使用视图:select * from视图名称;

三.修改视图alter view 视图名称 asSQL语句;

四.删除视图drop view视图名称;

五.查看视图

describe 视图名称;

六.查看视图信息

showtable status like '视图名';

七.查看视图详细信息

showcreate view视图名;

八.在views表中查看视图详细信息select * from information_schema.views;

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

#修改视图,原始表也跟着改

mysql> select * fromcourse;+-----+--------+------------+

| cid | cname | teacher_id |

+-----+--------+------------+

| 1 | 生物 | 1 |

| 2 | 物理 | 2 |

| 3 | 体育 | 3 |

| 4 | 美术 | 2 |

+-----+--------+------------+

4 rows in set (0.00sec)

mysql> create view course_view as select * fromcourse; #创建表course的视图

Query OK,0 rows affected (0.52sec)

mysql> select * fromcourse_view;+-----+--------+------------+

| cid | cname | teacher_id |

+-----+--------+------------+

| 1 | 生物 | 1 |

| 2 | 物理 | 2 |

| 3 | 体育 | 3 |

| 4 | 美术 | 2 |

+-----+--------+------------+

4 rows in set (0.00sec)

mysql> update course_view set cname='xxx'; #更新视图中的数据

Query OK,4 rows affected (0.04sec)

Rows matched:4 Changed: 4 Warnings: 0mysql> insert into course_view values(5,'yyy',2); #往视图中插入数据

Query OK,1 row affected (0.03sec)

mysql> select * fromcourse; #发现原始表的记录也跟着修改了+-----+-------+------------+

|

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
存储过程存储函数、触发器视图MySQL中都有各自的用途。 存储过程是一组预编译的SQL语句,可以在数据库中创建和存储,然后在需要的时候调用。它们的优点是可以实现模块化的设计,可以被多次调用,执行效率较高。存储过程通常用于执行复杂的数据库操作,例如数据的插入、更新、删除等。\[1\] 存储函数与存储过程类似,也是一组预编译的SQL语句,但它们返回一个值。存储函数可以用于计算、转换数据等操作,并且可以在SQL语句中直接调用。\[2\] 触发器是一种特殊的存储过程,它在数据库中的表上定义,并在特定的事件发生时自动触发执行。触发器通常用于实现数据的约束、触发复杂的业务逻辑等。\[2\] 视图是一种虚拟的表,它是基于一个或多个表的查询结果构建的。视图可以简化复杂的查询操作,提供更方便的数据访问方式。视图通常用于隐藏敏感数据、简化数据查询、提供数据的不同展示方式等。\[2\] 综上所述,存储过程存储函数、触发器视图MySQL中都有各自的用途,可以用于执行复杂的数据库操作、计算和转换数据、实现数据的约束和业务逻辑、以及提供方便的数据访问方式。 #### 引用[.reference_title] - *1* *2* [mysql中的视图触发器存储过程](https://blog.csdn.net/weixin_53002381/article/details/125796059)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [【MySQL基础】存储过程存储函数、触发器视图](https://blog.csdn.net/qq_38149054/article/details/123298777)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值