Mysql 视图&存储过程&触发器

初识:

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

  1. 视图 (View)

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

2.1 视图的用途

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

2.2 视图的创建语法

sql 复制代码
CREATE VIEW 视图名 AS
SELECT 列名1, 列名2, ...
FROM 表名
WHERE 条件;

2.3 示例:

sql 复制代码
CREATE VIEW employee_salary AS
SELECT name, salary
FROM employees
WHERE salary > 5000;
  1. 存储过程 (Stored Procedure)

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

3.1 存储过程的用途

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

3.2 存储过程的创建语法:

sql 复制代码
CREATE PROCEDURE 存储过程名 ([IN | OUT | INOUT] 参数名 数据类型,...)
BEGIN
    SQL 语句;
END;

3.3 示例

sql 复制代码
CREATE PROCEDURE GetEmployee(IN emp_id INT)
BEGIN
    SELECT * FROM employees WHERE id = emp_id;
END;

3.4 调用存储过程

sql 复制代码
CALL GetEmployee(1);

4 . 触发器 (Trigger)

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

4.1 触发器的用途

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

4.2 触发器的创建语法

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

4.3 示例:

sql 复制代码
CREATE TRIGGER before_employee_insert
BEFORE INSERT ON employees
FOR EACH ROW
BEGIN
    IF NEW.salary < 0 THEN
        SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Salary cannot be negative';
    END IF;
END;

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

5.总结:

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

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

相关推荐
顶点多余25 分钟前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
xiaokangzhe26 分钟前
MySQL 数据库操作
数据库·oracle
发际线还在2 小时前
互联网大厂Java三轮面试全流程实战问答与解析
java·数据库·分布式·面试·并发·系统设计·大厂
小王不爱笑1322 小时前
MyBatis 执行流程源码级深度解析:从 Mapper 接口到 SQL 执行的全链路逻辑
数据库·sql·mybatis
Seven972 小时前
MySQL语句执行深度剖析:从连接到执行的全过程
mysql
山峰哥3 小时前
SQL优化实战:从索引策略到执行计划的极致突破
数据库·sql·性能优化·编辑器·深度优先
总要冲动一次3 小时前
离线安装 percona-xtrabackup-24
linux·数据库·mysql·centos
lcrml4 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
阿达_优阅达4 小时前
告别手工对账:xSuite 如何帮助 SAP 企业实现财务全流程自动化?
服务器·数据库·人工智能·自动化·sap·企业数字化转型·xsuite
IvorySQL4 小时前
IvorySQL v5 发布后,我们想听听大家的使用体验
数据库·postgresql·开源