存储过程是一组SQL语句的集合,它们被封装在一个命名的过程中,并可以通过一个名称进行调用。存储过程通常具有输入参数、输出参数和返回值。
创建存储过程:
以下是一个简单的例子:
DELIMITER //
CREATE PROCEDURE GetEmployeeByID(IN employeeID INT)
BEGIN
SELECT * FROM employees WHERE id = employeeID;
END //
DELIMITER ;
使用CALL语句来调用存储过程,并传递必要的参数。
CALL GetEmployeeByID(1);
触发器是与表相关联的一段SQL代码,它在表的数据发生变化(插入、更新、删除)时自动执行。
使用CREATE TRIGGER语句创建触发器。以下是一个简单的例子:
CREATE TRIGGER before_insert_example
BEFORE INSERT ON your_table
FOR EACH ROW
BEGIN
-- Trigger code here
END;
触发器可以在表的不同事件上触发,如BEFORE INSERT、AFTER INSERT、BEFORE UPDATE、AFTER UPDATE、BEFORE DELETE、AFTER DELETE等。
触发器使用场景:
触发器常用于实现数据完整性、约束、审计等功能。