mysql存储过程和触发器的应用

***********【mysql 存储过程和触发器 -- 别安驹】*********************

1、什么情况下使用存储过程?

完成一些比较麻烦的逻辑,比如多表在mysql端的cpu很空闲的情况下,用存储过程是不错的选择,

1.1、简单的存储过程示例:简单写入

DELIMITER $$
USE `curl_test`$$
DROP PROCEDURE IF EXISTS `data_s`$$
CREATE DEFINER=`root`@`localhost` PROCEDURE `data_s`()

BEGIN

DECLARE i INT DEFAULT 0;

WHILE i < 1000 DO

INSERT INTO album(`artist_id`,`name`,`url`)
VALUES(i,‘别安驹‘,‘2015-10-01‘);

SET i = i + 1;

END WHILE;

END$$
DELIMITER ;

1.2、简单的存储过程示例:关联更新

DROP PROCEDURE IF EXISTS testProcedure;
CREATE PROCEDURE testProcedure()
BEGIN
DECLARE flag INT DEFAULT 0;
DECLARE tID INT;
DECLARE tDept CHAR(255);
DECLARE tAlias CHAR(20);
DECLARE cur CURSOR FOR SELECT id,dept FROM users;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET flag = 1;
OPEN cur;
FETCH cur INTO tID,tDept;
WHILE flag<>1 DO
SELECT alias FROM dept WHERE name = tDept INTO tAlias;
UPDATE users SET dept_alias=tAlias WHERE id=tID;
FETCH cur INTO tID,tDept;
END WHILE;
CLOSE cur;
END

存储过程的优点:

预编译,相对于直接的SQL效率会高点,同时可以降低SQL语句传输过程中消耗的流量;

简化业务逻辑,可以把需求转化给专业的DBA(如果有的话);

更方便的使用MySQL数据库事物的处理,尤其是购物类网站;

安全、用户权限更容易管理;

修改存储过程基本上不需要修改程序代码,而直接写SQL修改SQL一般都要修改相关的程序;

2、mysql触发器

触发器(trigger):监视某种情况,并触发某种操作。

触发器创建语法四要素:

2.1.监视地点(table)

2.2.监视事件(insert/update/delete)

2.3.触发时间(after/before)

2.4.触发事件(insert/update/delete)

语法:

create trigger triggerName

after/before insert/update/delete on 表名

for each row #这句话在mysql是固定的

begin

sql语句;

end;

触发器示例:"在album表新增数据的时候更新artist表的num字段减3"

DELIMITER $$

USE `curl_test`$$

DROP TRIGGER /*!50032 IF EXISTS */ `change_num`$$

CREATE
/*!50017 DEFINER = ‘root‘@‘localhost‘ */

TRIGGER `change_num` AFTER INSERT ON `album`
FOR EACH ROW BEGIN
UPDATE `artist` SET num=num-3;

END;
$$

DELIMITER ;
时间: 2024-12-23 18:38:54

mysql存储过程和触发器的应用的相关文章

mysql 存储过程 函数 触发器

mysql存储过程与函数 存储过程demo mysql> delimiter // -- 这里//为修改默认分隔符: mysql> CREATE PROCEDURE simpleproc (OUT param1 INT) -> BEGIN -> SELECT COUNT(*) INTO param1 FROM t; -> END// Query OK, 0 rows affected (0.00 sec) mysql> delimiter ; // -- 改回来这里的默

MySQL 存储过程/游标/触发器/事务

来源:http://www.cnblogs.com/zhuyp1015/p/3575823.html 将会用到的几个表 mysql> DESC products; +------------+--------------+------+-----+---------+----------------+| Field      | Type         | Null | Key | Default | Extra          |+------------+--------------+-

MySQL存储过程及触发器

一.存储过程 存储过程的基本格式如下: -- 声明结束符 -- 创建存储过程 DELIMITER $ -- 声明存储过程的结束符 CREATE PROCEDURE pro_test() --存储过程名称(参数列表) BEGIN -- 可以写多个sql语句; -- sql语句+流程控制 SELECT * FROM employee; END $ -- 结束 结束符 -- 执行存储过程 CALL pro_test(); -- CALL 存储过程名称(参数); -- 删除存储过程 DROP PROCE

存储过程和触发器——MySQL

从MySQL5.0版本开始就对存储过程和触发器进行了支持,在MySQL进行学习前,先查看您所使用的版本吧,方法有: 1.$mysql -V  //linux终端下 2.select version();  //mysql下 3. mysql --help | grep Distrib  //linux终端下 在了解您所使用的版本支持情况下再下一步 存储过程  sql语句执行的时候要先编译,然后执行.存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数

mysql 自定义存储过程和触发器

mysql 自定义存储过程和触发器 --存储过程示范 DROP PROCEDURE IF EXISTS PRO_TEST; CREATE PROCEDURE PRO_TEST(IN NUM_IN INT,OUT NUM_OUT INT,INOUT NUM_INOUT) BEGIN //DO ANYTHING YOU WANT END; 参数解释: in : 就是输入参数,输入参数是会被传入到存储过程作为参数使用,改变它的值将不会改变其原本值,相当于是值传递 out: 此为输出参数,在存储过程中为

mysql 查询表,视图,触发器,函数,存储过程

1. mysql查询所有表: SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '数据库名' AND  TABLE_TYPE ='BASE TABLE' mysql查询建表语句: show create table `表名` 2.mysql查询所有视图: SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '数据库名'

mysql的存储过程和触发器的使用 以及php中的调用方法

存储过程顾名思义,相当于一组为了完成特定功能的sql语句集,经编译后存储在数据库中.用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它.存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程. 存储过程的书写格式:  CREATE PROCEDURE [拥有者.]存储过程名[;程序编号]  [(参数#1,-参数#1024)]  [WITH  {RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}  ] 

【MySQL笔记】触发器,存储过程和函数

一.触发器 触发器(TRIGGER):是由事件来触发某个操作.当数据库系统执行这些事件时,就会激活触发器执行相应的操作.MySQL从5.0.2版本开始支持触发器. 触发事件:INSERT语句.UPDATE语句和DELETE语句. 1.创建触发器 1.1.创建只有一个执行语句的触发器 CREATE  TRIGGER 触发器名  BEFORE | AFTER  触发事件 ON  表名 FOR  EACH  ROW  执行语句 1.2.创建有多个执行语句的触发器 DELIMITER&& CREA

MySql中的存储过程和触发器的使用和区别

存储过程:是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它.存储过程是数据库中的一个重要对象 优点:1允许模块化程序设计(创建一次多次使用)2允许更快执行3减少网络流量4更好的安全机制 格式: DELIMITER // CREATE PROCEDURE 储存名([ IN ,OUT ,INOUT ]?参数名?数据类形...) BEGIN SQL语句 END //