Mysql--基础篇--视图,存储过程,触发器

1、视图

MySQL视图(View)是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。

视图作用:

  • 简化复杂的SQL操作:将复杂的SQL查询语句封装成一个简单的视图,用户只需要使用简单的SELECT语句就可以获取到想要的结果。
  • 抽象和保护数据:通过视图,可以只暴露部分数据给用户,隐藏敏感信息或复杂的表结构。
  • 提供一致的数据表示:即使底层表结构发生了变化,只要视图的逻辑不变,基于视图的应用程序就无需更改。
  • 聚合数据:视图可以用来创建汇总数据,比如通过SUM, COUNT等聚合函数对数据进行计算。

创建视图的基本语法如下:

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table_name
WHERE condition;

创建视图示例:
例如,假设有一个名为employees的表,你可以创建一个视图来显示所有部门编号为10的员工信息
sql:

CREATE VIEW dept_10_employees AS
SELECT employee_id, first_name, last_name
FROM employees
WHERE department_id = 10;

创建完视图之后,你可以像查询表一样查询视图。
使用视图:

SELECT * FROM dept_10_employees;

注意:
视图是读取时才执行其定义的查询,因此它们并不占用额外的存储空间(除了存储视图定义本身)。另外,一些视图是可以更新的,即可以通过视图来插入、更新或删除数据,但不是所有的视图都支持这些操作,这取决于视图的复杂程度以及基础表的结构。

2、存储过程

MySQL存储过程(Stored Procedure)是一组预编译的SQL语句,它被作为一个单元存储在数据库中。使用存储过程可以减少网络流量,因为客户端只需要发送一个调用存储过程的请求,而不是多条SQL命令。此外,存储过程还能提高代码的重用性和安全性,简化复杂的操作。

创建存储过程的基本语法如下:

DELIMITER //CREATE PROCEDURE procedure_name (IN parameter1 datatype, OUT parameter2 datatype, INOUT parameter3 datatype)
BEGIN-- SQL statements
END$$DELIMITER ;

解释:

  • DELIMITER //:更改结束符为//,这样可以避免与SQL语句中的分号冲突。
  • CREATE PROCEDURE:定义新的存储过程。
  • procedure_name:存储过程的名称。
  • IN, OUT, INOUT:参数模式,分别表示输入、输出和输入/输出参数。
  • datatype:参数的数据类型。
  • BEGIN … END:存储过程体,包含要执行的一系列SQL语句。
  • DELIMITER ;:还原结束符,更改为默认的;

创建并调用存储过程示例:
假设我们有一个名为employees的表,并且想要创建一个存储过程来获取某个部门的所有员工。
创建存储过程sql:

DELIMITER $$CREATE PROCEDURE get_dept_employees(IN dept_id INT)
BEGINSELECT employee_id, first_name, last_nameFROM employeesWHERE department_id = dept_id;
END$$DELIMITER ;

调用存储过程sql:

CALL get_dept_employees(10);

解释:
这将返回所有属于部门ID为10的员工信息。

带输出参数的存储过程示例:
如果我们需要计算某个部门的平均工资并将其作为输出参数返回
创建存储过程sql:

DELIMITER $$CREATE PROCEDURE avg_salary_by_dept(IN dept_id INT, OUT avg_salary DECIMAL(10, 2))
BEGINSELECT AVG(salary) INTO avg_salaryFROM employeesWHERE department_id = dept_id;
END$$DELIMITER ;

调用存储过程sql:

CALL avg_salary_by_dept(10, @average_salary);
SELECT @average_salary;

解释:
这会计算部门ID为10的员工的平均工资,并将结果存储到用户变量@average_salary中,然后通过SELECT语句显示出来。

修改和删除存储过程:

  • 修改存储过程:可以使用ALTER PROCEDURE命令,但通常需要先删除再重新创建存储过程以更新其内容。
  • 删除存储过程:使DROP PROCEDURE命令,如DROP PROCEDURE IF EXISTS procedure_name;。

注意事项:

  • 存储过程中可以包含控制结构(如IF, CASE, LOOP, REPEAT, WHILE等),以及游标(Cursor)用于逐行处理数据。
  • 如果存储过程内有错误,可能会导致整个事务失败。因此,在编写存储过程时,考虑使用TRY…CATCH(在MySQL 8.0+支持)或适当的错误处理机制。
  • 存储过程是数据库对象的一部分,因此它们的安全性也是重要的考量因素。可以通过权限管理来控制谁可以创建、修改或执行存储过程。

3、触发器

MySQL触发器(Trigger)是一种特殊的存储过程,它在特定的表上执行插入(INSERT)、更新(UPDATE)或删除(DELETE)操作时自动触发。触发器可以用来维护数据的完整性和一致性,执行复杂的业务规则,或者在数据库中实现事件驱动的逻辑。

触发器的组成部分:

  • 触发时机:可以是BEFORE(在操作之前触发)或AFTER(在操作之后触发)。BEFORE通常用于验证和修改输入的数据,而AFTER用于处理已完成的操作。
  • 触发事件:INSERT, UPDATE, 或DELETE,分别对应于插入、更新和删除操作。
  • 表名:触发器关联的表。
  • 触发器体:包含一组SQL语句,这些语句会在触发事件发生时执行。

创建触发器的基本语法:

CREATE TRIGGER trigger_name
{BEFORE | AFTER} {INSERT | UPDATE | DELETE} ON table_name
FOR EACH ROW
BEGIN-- SQL statements
END;

解释:

  • trigger_name:触发器的名字。
  • {BEFORE | AFTER}:触发器的触发时机。
  • {INSERT | UPDATE | DELETE}:触发器响应的事件类型。
  • table_name:触发器关联的表。
  • FOR EACH ROW:表示这个触发器将在每一行受影响时被调用一次。
  • BEGIN … END:触发器体,其中包含触发器要执行的SQL语句。

触发器中的特殊变量:

  • OLD.column_name:引用旧行的列值,仅适用于UPDATE和DELETE触发器。
  • NEW.column_name:引用新行的列值,仅适用于INSERT和UPDATE触发器。

示例:

(1)、插入时触发的触发器

假设我们有一个名为orders的订单表,并且每次插入新的订单时,我们都想记录下该订单的创建时间。
sql:

DELIMITER $$CREATE TRIGGER insert_order_timestamp
BEFORE INSERT ON orders
FOR EACH ROW
BEGINSET NEW.order_date = NOW();
END$$DELIMITER ;

解释:
orders表中,新增的每一行数据,会在插入前将order_date设置为当前时间。

(2)、更新时触发的触发器

如果我们想要确保价格不能低于0,并且在更新产品价格时记录下最后一次的价格变动。
sql:

DELIMITER $$CREATE TRIGGER update_product_price
BEFORE UPDATE ON products
FOR EACH ROW
BEGINIF NEW.price < 0 THENSET NEW.price = OLD.price; -- 保持原价不变END IF;INSERT INTO price_history (product_id, old_price, new_price, change_time)VALUES (NEW.product_id, OLD.price, NEW.price, NOW());
END$$DELIMITER ;

解释:
更新products表时,如果price字段的新值小于0,则price字段不更新。同时在price_history历史表中插入一条记录。

(3)、删除时触发的触发器

如果我们要在删除用户时,同时删除与该用户相关的所有订单。
sql:

DELIMITER $$CREATE TRIGGER delete_user_orders
AFTER DELETE ON users
FOR EACH ROW
BEGINDELETE FROM orders WHERE user_id = OLD.user_id;
END$$DELIMITER ;

解释:
删除users表数据时,同时删除当前用户在orders 表中的全部关联数据。

管理触发器:

  • 查看触发器:可以使用SHOW TRIGGERS命令来查看当前数据库中的所有触发器。
  • 删除触发器:使用DROP TRIGGER命令来删除一个触发器,如DROP TRIGGER IF EXISTS trigger_name;。

注意事项:

  • 触发器应当谨慎使用,因为它们会增加数据库操作的复杂性,并可能影响性能。
  • 触发器可能会导致意外的行为,特别是在多个触发器相互作用的情况下。因此,测试是非常重要的。
  • 触发器不能直接调用,只能通过它们所关联的表上的DML(数据操纵语言)操作来触发。
  • 在设计触发器时,请考虑事务的影响。触发器内的操作和触发它的DML语句是在同一个事务中执行的。如果触发器内有任何错误,整个事务可能会回滚。

乘风破浪会有时,直挂云帆济沧海!!!

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

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

相关文章

某团 mtgsig1.2 | sdkVersion: 3.0.0 签名算法分析记录(2025/1/9)

【作者主页】&#xff1a;小鱼神1024 【擅长领域】&#xff1a;JS逆向、小程序逆向、AST还原、验证码突防、Python开发、浏览器插件开发、React前端开发、NestJS后端开发等等 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;不提供完整代码&#…

(二)最长公共子序列、最长上升子序列、最大子段和、三角形最小路径和、矩阵连乘、0-1背包

最近刚考完算法设计分析课的考试&#xff0c;复习总结一下期末考试的几道算法题吧 目录 LCR 095. 最长公共子序列 300. 最长递增子序列 53. 最大子数组和 LCR 100. 三角形最小路径和 矩阵连乘问题 0-1背包 LCR 095. 最长公共子序列 给定两个字符串 text1 和 text2&#xff…

聚类系列 (二)——HDBSCAN算法详解

在进行组会汇报的时候&#xff0c;为了引出本研究动机&#xff08;论文尚未发表&#xff0c;暂不介绍&#xff09;&#xff0c;需要对DBSCAN、OPTICS、和HDBSCAN算法等进行详细介绍。在查询相关资料的时候&#xff0c;发现网络上对于DBSCAN算法的介绍非常多与细致&#xff0c;但…

通义灵码在跨领域应用拓展之物联网篇

目录 一.引言 二.通义灵码简介 三.通义灵码在物联网领域的设备端应用 1.传感器数据采集 (1).不同类型传感器的数据读取 (2).数据转换与预处理 2.设备控制指令接收和执行 (1).指令解析与处理 (2).设备动作执行 四.通义灵码在物联网领域的云端平台应用 1.数据存储和管…

DolphinScheduler自身容错导致的服务器持续崩溃重大问题的排查与解决

01 问题复现 在DolphinScheduler中有如下一个Shell任务&#xff1a; current_timestamp() { date "%Y-%m-%d %H:%M:%S" }TIMESTAMP$(current_timestamp) echo $TIMESTAMP sleep 60 在DolphinScheduler将工作流执行策略设置为并行&#xff1a; 定时周期调度设置…

CISAW-ES应急服务方向信息安全事件分级

网络安全事件事件分级 网络安全事件分为四级&#xff1a;特别重大网络安全事件、重大网络安全事大网络安全事件、一般网络安全事件。 1&#xff0e;特别重大网络安全事件 符合下列情形之一的&#xff0c;为特别重大网络安全事件。 &#xff08;1&#xff09;重要网络和信息系…

油猴支持阿里云自动登陆插件

遇到的以下问题,都已在脚本中解决: 获取到的元素赋值在页面显示,但是底层的value并没有改写,导致请求就是获取不到数据元素的加载时机不定,尤其是弱网情况下,只靠延迟还是有可能获取不到,且登陆不丝滑,通过元素发现机制,解决此问题并做到丝滑登陆根据密钥计算校验码之…

B树与B+树:数据库索引的秘密武器

想象一下&#xff0c;你正在构建一个超级大的图书馆&#xff0c;里面摆满了各种各样的书籍。B树和B树就像是两种不同的图书分类和摆放方式&#xff0c;它们都能帮助你快速找到想要的书籍&#xff0c;但各有特点。 B树就像是一个传统的图书馆摆放方式&#xff1a; 1. 书籍摆放&…

城市生命线安全综合监管平台

【落地产品&#xff0c;有需要可留言联系&#xff0c;支持项目合作或源码合作】 一、建设背景 以关于城市安全的重要论述为建设纲要&#xff0c;聚焦城市安全重点领域&#xff0c;围绕燃气爆炸、城市内涝、地下管线交互风险、第三方施工破坏、供水爆管、桥梁坍塌、道路塌陷七…

成为LabVIEW自由开发者

成为LabVIEW自由开发者的体验可以非常丰富且具有挑战性&#xff0c;同时也充满了自我成长和多样化项目的机会。 ​ 1. 高度的灵活性与自由度 工作时间与地点&#xff1a;作为自由开发者&#xff0c;你可以自由选择工作时间和地点。你可以在家工作&#xff0c;也可以选择在咖啡…

用于与多个数据库聊天的智能 SQL 代理问答和 RAG 系统(3) —— 基于 LangChain 框架的文档检索与问答功能以及RAG Tool的使用

介绍基于 LangChain 框架的文档检索与问答功能&#xff0c;目标是通过查询存储的向量数据库&#xff08;VectorDB&#xff09;&#xff0c;为用户的问题检索相关内容&#xff0c;并生成自然语言的答案。以下是代码逻辑的详细解析&#xff1a; 代码结构与功能 初始化环境与加载…

基于QT和C++的实时日期和时间显示

一、显示在右下角 1、timer.cpp #include "timer.h" #include "ui_timer.h" #include <QStatusBar> #include <QDateTime> #include <QMenuBar> Timer::Timer(QWidget *parent) :QMainWindow(parent),ui(new Ui::Timer) {ui->setup…

Elasticsearch学习(1) : 简介、索引库操作、文档操作、RestAPI、RestClient操作

目录 1.elasticsearch简介1.1.了解es1.2.倒排索引正向索引和倒排索引 1.3.es的一些概念:文档和字段&#xff1b;索引和映射&#xff1b;Mysql与ES1.4.安装es、kibana部署单点es部署kibanaIK分词器安装IK分词器与测试扩展与停用词词典总结 部署es集群 2.索引库操作2.1.mapping映…

【LeetCode Hot100 贪心算法】 买卖股票的最佳时机、跳跃游戏、划分字母区间

贪心算法 买卖股票的最佳时机买卖股票的最佳时机II跳跃游戏跳跃游戏II划分字母区间 买卖股票的最佳时机 给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票&#xff0c;并选择在 未来的某一个不同的…

如何在 Ubuntu 22.04 上使用 LEMP 安装 WordPress 教程

简介&#xff1a; 本教程旨在指导你如何在 Ubuntu 22.04 上使用 LEMP 栈安装 WordPress。 WordPress 是一个用 PHP 编写的开源内容管理系统。LEMP 栈是 Linux&#xff0c;NGINX&#xff0c;MySQL 和 PHP 的缩写。WordPress 非常用户友好&#xff0c;并提供了多种选项&#xff…

vue实现虚拟列表滚动

<template> <div class"cont"> //box 视图区域Y轴滚动 滚动的是box盒子 滚动条显示的也是因为box<div class"box">//itemBox。 一个空白的盒子 计算高度为所有数据的高度 固定每一条数据高度为50px<div class"itemBox" :st…

STM32小实验2

定时器实验 TIM介绍 TIM&#xff08;Timer&#xff09;定时器 定时器可以对输入的时钟进行计数&#xff0c;并在计数值达到设定值时触发中断 16位计数器、预分频器、自动重装寄存器的时基单元&#xff0c;在72MHz计数时钟下可以实现最大59.65s的定时 不仅具备基本的定时中断…

HTB:Timelapse[WriteUP]

目录 连接至HTB服务器并启动靶机 信息收集 使用rustscan对靶机TCP端口进行开放扫描 提取并保存靶机TCP开放端口号 使用nmap对靶机TCP开放端口进行脚本、服务扫描 使用nmap对靶机TCP开放端口进行漏洞、系统扫描 使用nmap对靶机常用UDP端口进行开放扫描 使用nmap对靶机UD…

【贵州省】乡镇界arcgis格式shp数据乡镇名称和编码内容下载测评

shp数据字段乡镇名称和编码&#xff0c;坐标是wgs84&#xff0c;数据为SHP矢量格式&#xff0c;下载下来直接加载进ArcMap即可使用 下载地址&#xff1a;https://download.csdn.net/download/zhongguonanren99/14928126

[免费]微信小程序(高校就业)招聘系统(Springboot后端+Vue管理端)【论文+源码+SQL脚本】

大家好&#xff0c;我是java1234_小锋老师&#xff0c;看到一个不错的微信小程序(高校就业)招聘系统(Springboot后端Vue管理端)&#xff0c;分享下哈。 项目视频演示 【免费】微信小程序(高校就业)招聘系统(Springboot后端Vue管理端) Java毕业设计_哔哩哔哩_bilibili 项目介绍…