当前位置: 首页 > news >正文

Mysql 视图存储过程触发器

初识:

        在 MySQL 中,视图(View)、存储过程(Stored Procedure)和触发器(Trigger)是用于管理和操作数据库的高级功能。它们各自有不同的用途和优势。

2. 视图 (View)

        视图是一个虚拟表,它是从一个或多个表中获取数据的结果。视图并不存储数据本身,而是保存查询结果的结构。因此,视图可以用于简化复杂的查询,并提高代码的可读性和可维护性。 

        2.1 视图的用途

  • 简化复杂的 SQL 查询。
  • 对敏感数据进行访问控制,展示部分数据。
  • 提供一致的数据接口给用户或应用程序。 

        2.2 视图的创建语法

CREATE VIEW 视图名 AS
SELECT 列名1, 列名2, ...
FROM 表名
WHERE 条件;

        2.3 示例:

CREATE VIEW employee_salary AS
SELECT name, salary
FROM employees
WHERE salary > 5000;

        3. 存储过程 (Stored Procedure)

                存储过程是预编译的 SQL 语句集合,存储在数据库中,并可以重复调用。存储过程通过减少网络通信、重用代码、以及更好地管理事务来提高数据库的性能。

        3.1 存储过程的用途

  • 自动化重复性操作。
  • 减少网络通信负担。
  • 提供参数化的复杂操作。

        3.2 存储过程的创建语法:

CREATE PROCEDURE 存储过程名 ([IN | OUT | INOUT] 参数名 数据类型,...)
BEGINSQL 语句;
END;

        3.3 示例:   

CREATE PROCEDURE GetEmployee(IN emp_id INT)
BEGINSELECT * FROM employees WHERE id = emp_id;
END;

        3.4 调用存储过程

CALL GetEmployee(1);

        4. 触发器 (Trigger)

        触发器是当数据库中的某个事件(如插入、更新或删除)发生时自动执行的 SQL 代码。它通常用于执行自动化任务,例如数据验证、记录历史数据、维护数据一致性等。      

        4.1 触发器的用途

  • 自动进行数据检查和验证。
  • 维护数据的完整性和一致性。
  • 记录数据更改历史。

        4.2 触发器的创建语法

CREATE TRIGGER 触发器名
{BEFORE | AFTER} {INSERT | UPDATE | DELETE}
ON 表名 FOR EACH ROW
触发器体;

        4.3 示例:

CREATE TRIGGER before_employee_insert
BEFORE INSERT ON employees
FOR EACH ROW
BEGINIF NEW.salary < 0 THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Salary cannot be negative';END IF;
END;

        在这个例子中,当插入员工记录时,如果工资为负数,则触发器会阻止插入操作并抛出错误。

5.总结:

  • 视图:虚拟表,用于简化复杂查询或限制数据访问。不保存查询结果,只保存查询的SQL逻辑。(简单,安全,数据独立)
  • 存储过程:预编译的 SQL 语句集,用于执行复杂逻辑。
  • 触发器:自动在特定数据库事件发生时执行的 SQL 代码,常用于维护数据完整性。

        这些工具在数据库管理中可以大大简化操作、提高性能并确保数据的准确性。

http://www.lryc.cn/news/440782.html

相关文章:

  • 【天池比赛】【零基础入门金融风控 Task2赛题理解】实战进行中……20240915更新至2.3.4.3 查看训练集测试集中特征属性只有一值的特征
  • 配置Windows内核开发环境
  • nanoGPT用红楼梦数据从头训练babyGPT-12.32M实现任意问答
  • PDF转图片的思路思考
  • lnmp - 登录技术方案设计与实现
  • 如何在 Qt 的 QListWidget 中逐行添加和显示数据
  • Java API 之集合框架进阶
  • Java String isEmpty()方法
  • Redisson分布式锁分析,可重入、可续锁(看门狗)
  • C++掉血迷宫
  • Spring Boot- 数据库相关问题
  • 秒懂C++之特殊类设计
  • 人工智能学习
  • WINDOWS AGENTARENA:EVALUATING MULTI-MODAL OS AGENTS AT SCALE论文学习
  • 3步轻松定制报价方案,亿发商城报价神器你用过了吗?
  • CISP备考题库(五)
  • 【Kubernetes】常见面试题汇总(二十三)
  • linux-Shell 编程-Shell 脚本基础
  • Linux运维篇-tigervnc工具的使用
  • 基于Spark的电影推荐系统设计与实现(论文+源码)_kaic
  • 基于python+django+vue的医院预约挂号系统
  • 镀金引线---
  • 『功能项目』窗口可拖拽脚本【59】
  • Map--08--CurrentHashMap 与 Hashtable的异同?
  • Docker学习笔记(三)存储与卷
  • 硬件工程师笔试面试——滤波器
  • 【SpringBoot3】面向切面 AspectJ AOP 使用详解
  • wav怎么转mp3格式?给你推荐几种音频格式转换方法
  • Redis的AOF持久化、重写机制、RDB持久化、混合持久化
  • Dom4j使用xpath查询xml文