MySQL-视图、存储过程和触发器

一、视图的定义和使用 

        视图是从一个或者几个基本表(或视图)导出的表。它与基本表不同,是一个虚表,视图只能用来查询。不能做增删改查(虚拟的表)

1.视图的作用

  1. 简化查询
  2. 重写格式化数据
  3. 频繁访问数据库
  4. 过滤数据
2.创建视图

-- 创建视图
-- 语法:create view 视图名 【view_xxx / v_xxx】
-- as 查询语句


CREATE VIEW v_stu_man AS
SELECT * FROM student WHERE ssex = '男';
3.视图的使用
-- 视图的使用
SELECT * FROM v_stu_man;

运用:

//创建一个新视图
CREATE VIEW v_vstuman_class AS
SELECT v_stu_man.*,classname FROM v_stu_man
LEFT JOIN class ON v_stu_man.classid = class.classid
//使用这个视图
SELECT * FROM v_vstuman_class

若修改表中的Sid = 1的Sname='赵蕾蕾',查看数据显示结果

UPDATE student SET sname = '赵蕾蕾' WHERE sid = 1

4.查看库中所有的视图
-- 查看库中所有的视图
SELECT * FROM
information_schema.VIEWS 
WHERE table_schema = 'schoolp';

5.删除视图 
-- 删除视图
DROP VIEW v_stu_man;

二、存储过程的创建和使用

1.什么是存储过程

        存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后,再次调用不需要重复编译,用户通过指定存储过程的名字并给出参数 (如果该存储过程带有参数)来执行它。

简单来讲就是:SQL语句集+预编译+特定功能

2.为什么要使用存储过程
  1. 业务流程复杂:业务复杂时,SQL语句相互依赖, 顺序执行;
  2. 频繁访问数据库:每条SQL语句都需单独连接和访 问数据库;
  3. 先编译后执行:SQL语句的执行需要先编译。
3.创建存储过程

语法:# 存储过程
-- create procedure 存储过程名字【proc_xxx】(形参列表)
-- begin
--     一组sql语句集
-- end

-- 创建最简单存储过程
DELIMITER $$
CREATE PROCEDURE proc_test()
BEGINSELECT * FROM student;
END  $$
DELIMITER;
4.存储过程的操作
调用存储过程CALL 存储过程名 [参数名]
查看存储过程SELECT * FROM information_schema.ROUTINES WHERE routine_schema=‘库名’
删除存储过程DROP PROCEDURE 存储过程名;
-- 存储过程的基本用法
DELIMITER $$ -- 定制定界符
creat PROCEDURE pro_showstudent()
BEGINSELECTstudent.Sname,student.birthday,student.classid,student.Sid,student.Ssex
FROM student 
LEFT JOIN sc  ON student.Sid = sc.Sid
LEFT JOIN course ON course.Cid = sc.Cid
END$$
DELIMITER ; -- 恢复默认的定界符
CALL pro_showstudent();
-- 带参数的存储过程
DELIMITER $$
CREATE PROCEDURE proc_test2(IN a INT,   -- in 只入参(值传递)OUT b INT,  -- out 只出参 (无)INOUT c INT -- inout 出入参 (引用传递)
)
BEGIN SET a = a+1;SET b = b+100;SET c = c+1000;
END $$
DELIMITER ;-- 环境变量  @ 局部环境变量  @@ 全局环境变量
SET @X = 10;   
SET @Y = 20;     
SET @z = 30;      SELECT @X, @Y, @z;CALL proc_test2(@X,@Y,@z)SELECT @X, @Y, @z;

(面试题)写一个分页的存储过程

DELIMITER $$
CREATE PROCEDURE proc_stuPage(IN curpage INT,-- IN sizepage INT,OUT stucount INT,OUT pagecount INT
)
BEGIN DECLARE cp INT;-- 声名和定义局部变量的语句SET cp = (curpage-1)*sizepage;SELECT COUNT(*) FROM student INTO stucount;SET pagecount = CEILING(stucount / sizepage); -- ceiling 向上取整SELECT * FROM student LIMIT (curpage-1)*sizepage;,sizepage;
END $$
DELIMITER ;SET @a = 0;
SET @b = 0;
CALL proc_stuPage(2,3,@a,@b);SELECT @a,@b

5.存储过程与函数的区别
语法关键字不同,存储过程是procedure, 函数是function;
执行存储过程可以独立执行,函数必须依 赖表达式的调用;
返回值存储过程可以定义多个返回结果, 函数只有一个返回值;
功能函数不易做复杂的业务逻辑,但是存 储过程可以。
6.存储过程的缺陷
维护性存储过程的维护成本高,修改调试较为麻烦。
移植性大多数关系型数据库的存储过程存在细微差异。
协作性没有相关的版本控制或者IDE,团 队中对于存储过程的使用大多是 依赖文档。

三、触发器

1.什么是触发器

.

一种存储过程与表相关联自动执行
 触发器是数据库中针对数据库表操作触发的 特殊的存储过程。
2.创建触发器
DELIMITER $$
CREATE TRIGGER trig_delstu_delsc
BEFORE DELETE ON student FOR EACH ROW 
BEGIN -- old 已经存在的数据 、 new  还不存在的数据DELETE FROM sc WHERE sid = old.sid;
END $$
DELIMITER ;
3.触发器的查看
SELECT * FROM information_schema.`TRIGGERS`
WHERE trigger_schema = 'schoolp'

四、存储过程和触发器的区别

语法关键字不同,存储 过程是procedure, 触发器是trigger;
执行存储过程需要调用才执 行,触发器自动执行;
返回值存储过程可以定义返回值, 但是触发器没有返回值;
功能存储过程是一组特定功能的 SQL语句,触发器则是SQL语 句前后执行,本身不影响原功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/384838.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【MATLAB APP】建立独立桌面APP

背景:已有MATLAB APP的.mlapp文件,但客户提出需要可以直接使用的exe文件。 要求:点开即用,无需下载MATLAB。使用者无法修改APP的代码。 一、环境配置 APP创建者:安装MATLAB R2023a,配置Application Compile…

【开源库编译 | zlib】 zlib库最新版本(zlib-1.3.1)在Ubuntu(Linux)系统下的 编译 、交叉编译(移植)

😁博客主页😁:🚀https://blog.csdn.net/wkd_007🚀 🤑博客内容🤑:🍭嵌入式开发、Linux、C语言、C、数据结构、音视频🍭 🤣本文内容🤣&a…

通信原理-实验六:实验测验

实验六 实验测验 一:测验内容和要求 测试需要完成以下几个步骤: 配置好以下网络图;占总分10%(缺少一个扣一分)根据下面图配置好对应的IP和网关以及路由等相关配置,保证设备之间连通正常;占总…

【学一点儿前端】本地或jenkins打包报错:getaddrinfo ENOTFOUND registry.nlark.com.

问题 今天jenkins打包一个项目,发现报错了 error An unexpected error occurred: "https://registry.nlark.com/xxxxxxxxxx.tgz: getaddrinfo ENOTFOUND registry.nlark.com". 先写解决方案 把yarn.lock文件里面的registry.nlark.com替换为registry.npmmi…

【计算机网络】期末实验答辩

注意事项: 1)每位同学要在下面做过的实验列表中选取三个实验进行答辩准备,并将自己的姓名,学号以及三个实验序号填入共享文档"1(2)班答辩名单"中。 2)在答辩当日每位同学由老师在表…

【React】事件绑定:深入解析高效处理用户交互的最佳实践

文章目录 一、什么是事件绑定?二、基本事件绑定三、绑定 this 上下文四、传递参数五、事件对象六、事件委托七、常见事件处理八、优化事件处理 React 是现代前端开发中最受欢迎的框架之一,其组件化和高效的状态管理能力使得构建复杂的用户界面变得更加容…

**卷积神经网络典型CNN**

SeNet SeNet(Squeeze-and-Excitation Networks)是ImageNet 2017年分类任务冠军,核心思想是:Squeeze(挤压、压缩)和Excitation(激励)两个操作,其主要目的是通过显示的构建特征通道之间的相互依赖关系,采用特征重定向的策略&#x…

光明乳业:以科技赋能品质,引领乳业绿色新未来

近日,光明乳业再次成为行业焦点,其在科技创新与绿色发展方面的卓越表现赢得了广泛赞誉。作为中国乳制品行业的领军企业,光明乳业始终坚守品质至上的原则,不断探索科技创新之路,致力于为消费者提供更高品质、更健康的乳…

webStorm 实时模板笔记

文章目录 1、单斜杠效果 2、双斜杠效果 3、控制台打印效果 1、单斜杠 /** $END$ */效果 2、双斜杠 /*** $END$* author Ikun* since $DATE$ $TIME$ */DATE date() ✔ TIME time() ✔效果 3、控制台打印 console.log("███████$EXPR_COPY$>>>>&a…

Internxt:适用于Linux开源安全云存储平台

有无数的云存储平台为您的文件提供安全可靠的存储空间。可在 Linux 上安装的热门云存储应用程序包括Dropbox、Nextcloud和Google Drive,遗憾的是,后者迄今为止不提供 Linux 客户端。 其他自托管选项包括OwnCloud、Pydio Cells、Seafile、Resilio和Synct…

暑期C++ printf和scanf的平替

有任何不懂的问题可以评论区留言&#xff0c;能力范围内都会一一回答 C中也有专门的输入和输出的方法 首先我们需要一个头文件&#xff0c;也就是#include<iostream> 然后根据我们命名空间的知识可知这个地方如果我们要使用必须先展开 可以全部展开比如using namespa…

Godot入门 04平台设计

新建创景&#xff0c;添加AnimatableBody2D节点。 添加Sprite2D节点 拖动图片 剪裁图片&#xff0c;吸附模式&#xff1a;像素吸附 添加CollisionShape2D&#xff0c;设置实际形状为矩形 重命名AnimatableBody2D节点为Platform&#xff0c;保存场景&#xff0c;拖动platform场景…

pikachu靶场之目录遍历、敏感信息泄露

一、目录遍历 漏洞概述 在web功能设计中,很多时候我们会要将需要访问的文件定义成变量&#xff0c;从而让前端的功能便的更加灵活。 当用户发起一个前端的请求时&#xff0c;便会将请求的这个文件的值(比如文件名称)传递到后台&#xff0c;后台再执行其对应的文件。 在这个过…

VSCode切换默认终端

我的VSCode默认终端为PowerShell&#xff0c;每次新建都会自动打开PowerShell。但是我想让每次都变为cmd&#xff0c;也就是Command Prompt 更改默认终端的操作方法如下&#xff1a; 键盘调出命令面板&#xff08;CtrlShiftP&#xff09;中,输入Terminal: Select Default Prof…

C++程序的UI界面闪烁问题的解决办法总结

Windows C++程序复杂的UI界面要使用多种绘图技术(使用GDI、GDI+、ddraw、D3D等绘图),并要贴图去美化,在窗口移动或者改变大小的时候可能会出现闪烁。下面罗列一下UI界面产生闪烁的几种可能的原因,并给出相应的解决办法。 1、原因一 如果熟悉显卡原理的话,调用GDI函数向屏…

重塑生态体系 深挖应用场景 萤石诠释AI时代智慧生活新图景

7月24日&#xff0c;“智动新生&#xff0c;尽在掌控”2024萤石夏季新品发布会在杭州举办。来自全国各地的萤石合作伙伴、行业从业者及相关媒体&#xff0c;共聚杭州&#xff0c;共同见证拥抱AI的萤石&#xff0c;将如何全新升级&#xff0c;AI加持下的智慧生活又有何不同。 发…

Git仓库拆分和Merge

1. 问题背景 我们原先有一个项目叫open-api&#xff0c;后来想要做租户独立发展&#xff0c;每个租户独立成一个项目&#xff0c;比如租户akc独立部署一个akc-open-api&#xff0c;租户yhd独立部署一个yhd-open-api&#xff0c;其中大部分代码是相同的&#xff0c;少量租户定制…

记录一次centos部署node高版本踩坑记录

前情回顾 大概在上周四的时候&#xff0c;我使用nuxt3把我上上周做的nuxt2项目重构了一遍&#xff0c;重构的时候感觉爽到飞起&#xff0c;vitevue3ts的感觉确实不错&#xff0c;再加上nuxt3的setup模板语法&#xff0c;写的得心应手 在项目写完之后我打算重新部署来替换之前…

学习笔记-系统框图传递函数公式推导

目录 *待了解 现代控制理论和自动控制理论区别 自动控制系统的组成 信号流图 1、系统框图 1.1、信号线、分支点、相加点 1.2、系统各环节间的连接 1.3、 相加点和分支点的等效移动&#xff08;比较点、引出点&#xff09; 2、反馈连接公式推导 2.1、前向通路传递函数…

android13 Settings动态显示隐藏某一项

总纲 android13 rom 开发总纲说明 目录 1.前言 2.确定目标设置项 3.修改参考 3.1 方法1 3.2 方法2 4.编译测试 5.彩蛋 1.前言 在Android 13系统中,动态显示或隐藏Settings应用中的某一项通常涉及到对Settings应用的内部逻辑进行修改。由于Settings应用是一个系统应用…