转载自:http://blog.chinaunix.net/uid-23302288-id-3785111.html
■存储过程Stored Procedure
存储过程就是保存一系列SQL命令的集合,将这些sql命令有组织的形成一个小程序,这样会实现很复杂的处理
SQL基本是一个命令一个命令执行,虽然可以通过连接、子查询等实现些高级的处理,但局限性是显而易见的
■存储过程的优势
1.提高执行性能(存储过程事先完成了解析、编译的处理,执行时能减轻数据库负担)
2.可减轻网络负担(比起多次传递SQL命令本身,这大大减轻了网络负担)
3.可防止对表的直接访问(可只赋予用户对相关存储过程的访问权限)
4.存储过程会保存在数据库中,应用程序只需要知道调用哪个存储过程就可以完成相应处理
■使用存储过程
参数种类分为: IN(输入型),OUT(输出型), INOUT(输入输出型)
SELECT column1.. INTO 变量1... FROM table1 WHERE xxx; //这个变量1对应OUT,INOUT
create procedure 存储过程名(
参数种类1 参数1 参数类型1
参数种类2 参数2 参数类型2...)
begin
处理内容
end
DELIMITER //
CREATE PROCEDURE search_customer(
IN p_nam VARCHAR(20))
BEGIN
IF p_nam IS NULL OR p_nam = '' THEN
SELECT * FROM customer;
ELSE
SELECT * FROM customer WHERE nam LIKE p_nam;
END IF;
END
//
DELIMITER ;
■注意事项
1.DELIMITER命令改变分隔符
默认分隔符是';' 存储过程中肯定会有';' ,所以使用其将分隔符改为'//' , 创建好后,在将分隔符改回';'
2.可使用的控制语句
IF语句
IF situation=1 THEN
command1;
ELSEIF situation=2 THEN
command2;
ELSE
command3;
END IF ;
CASE语句
CASE situation
WHEN 1 THEN command1;
WHEN 2 THEN command2;
WHEN 3 THEN command3;
ELSE command4;
END CASE;
WHILE (前置判断) 根据条件,循环有可能一次不执行
WHILE situation >1 DO
command1;
END WHILE;
REPEAT (后置判断) 不论条件如何,循环至少会执行一次 command1
REPEAT
command1;
UNTIL situation<=1 END REPEAT;
3.查看创建的存储过程状态
SHOW PROCEDURE STATUS \G;
SHOW CREATE PROCEDURE search_nam \G;
4.删除存储过程
DROP PROCEDURE search_nam;
5.执行存储过程
CALL search_nam('li%');
CALL search_nam('');
创建存储函数
mysql> DELIMITER //
mysql> CREATE PROCEDURE search_nam(
-> IN p_nam VARCHAR(20))
-> BEGIN
-> IF p_nam IS NULL OR p_nam='' THEN
-> SELECT * FROM USER3;
-> ELSE
-> SELECT * FROM USER3 WHERE name LIKE p_nam;
-> END IF;
-> END
-> //
Query OK, 0 rows affected (0.05 sec)
mysql> DELIMITER ;
查看创建的存储函数语句
mysql> SHOW CREATE PROCEDURE search_nam \G;
*************************** 1. row ***************************
Procedure: search_nam
sql_mode:
Create Procedure: CREATE DEFINER=`root`@`localhost` PROCEDURE `search_nam`(
IN p_nam VARCHAR(20))
BEGIN
IF p_nam IS NULL OR p_nam='' THEN
SELECT * FROM USER3;
ELSE
SELECT * FROM USER3 WHERE name LIKE p_nam;
END IF;
END
1 row in set (0.00 sec)
查看创建的存储函数状态
mysql> SHOW PROCEDURE STATUS \G;
*************************** 1. row ***************************
Db: test
Name: search_nam
Type: PROCEDURE
Definer: root@localhost
Modified: 2011-08-13 05:40:12
Created: 2011-08-13 05:40:12
Security_type: DEFINER
Comment:
1 row in set (0.00 sec)
调用存储过程 成功
mysql> CALL search_nam('aa%');
+------+------+
| id | name |
+------+------+
| 1 | aaa |
+------+------+
1 row in set (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
mysql> CALL search_nam('');
+------+------+
| id | name |
+------+------+
| 1 | aaa |
| 2 | bbb |
| 3 | ccc |
+------+------+
3 rows in set (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
演示OUT类型参数
mysql> DELIMITER //
mysql> CREATE PROCEDURE search_nam2(
-> IN p_nam VARCHAR(20),
-> OUT p_num INT)
-> BEGIN
-> IF p_nam IS NULL OR p_nam='' THEN
-> SELECT * FROM user3;
-> ELSE
-> SELECT * FROM USER3 WHERE name LIKE p_nam;
-> END IF;
-> SELECT FOUND_ROWS() INTO p_num;
-> END
-> //
mysql> DELIMITER ;
mysql> SHOW PROCEDURE STATUS ;
+------+-------------+-----------+----------------+---------------------+---------------------+
| Db | Name | Type | Definer | Modified | Created |
+------+-------------+-----------+----------------+---------------------+---------------------+
| test | search_nam | PROCEDURE | root@localhost | 2011-08-13 05:40:12 | 2011-08-13 05:40:12 |
| test | search_nam2 | PROCEDURE | root@localhost | 2011-08-13 05:56:37 | 2011-08-13 05:56:37 |
+------+-------------+-----------+----------------+---------------------+---------------------+
2 rows in set (0.00 sec)
调用成功
mysql> CALL search_nam3('bb%',@num);
+------+------+
| id | name |
+------+------+
| 2 | bbb |
+------+------+
1 row in set (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT @num;
+------+
| @num |
+------+
| 1 |
+------+
1 row in set (0.00 sec)
IF多分枝演示
mysql> DELIMITER //
mysql> CREATE PROCEDURE depart(
-> IN de_nam VARCHAR(10))
-> BEGIN
-> IF de_nam=1 THEN
-> SELECT * FROM USER3 WHERE depart='IT';
-> ELSEIF de_nam=2 THEN
-> SELECT * FROM USER3 WHERE depart='HR';
-> ELSE
-> SELECT * FROM USER3 WHERE depart='BOSS';
-> END IF;
-> END
-> //
Query OK, 0 rows affected (0.00 sec)
mysql> DELIMITER ;
mysql> CALL depart(2); //演示成功
+------+------+--------+
| id | name | depart |
+------+------+--------+
| 2 | bbb | HR |
+------+------+--------+
1 row in set (0.00 sec)
CASE演示
mysql> CREATE PROCEDURE depart2(
-> IN de_num INT)
-> BEGIN
-> CASE de_num
-> WHEN 1 THEN
-> SELECT * FROM USER3 WHERE depart='IT';
-> WHEN 2 THEN
-> SELECT * FROM USER3 WHERE depart='HR';
-> ELSE
-> SELECT * FROM USER3 WHERE depart='BOSS';
-> END CASE;
-> END
-> //
Query OK, 0 rows affected (0.00 sec)
mysql> DELIMITER ;
mysql> CALL depart2(1);
+------+------+--------+
| id | name | depart |
+------+------+--------+
| 1 | aaa | IT |
+------+------+--------+
1 row in set (0.00 sec)
Query OK, 0 rows affected (0.00 sec) //演示成功
mysql> CALL depart2(2);
+------+------+--------+
| id | name | depart |
+------+------+--------+
| 2 | bbb | HR |
+------+------+--------+
1 row in set (0.00 sec)
声明局部变量:
DECLARE tmp CHAR(10) [值];
给变量赋值:
SET tmp='值' ;
mysql> DELIMITER //
mysql> CREATE PROCEDURE depart3(
-> IN p_num INT)
-> BEGIN
-> DECLARE tmp CHAR(5);
-> CASE p_num
-> WHEN 1 THEN
-> SET tmp='IT';
-> WHEN 2 THEN
-> SET tmp='HR';
-> ELSE
-> SET tmp='BOSS';
-> END CASE;
->
SELECT * FROM USER3 WHERE depart=tmp;
-> END
-> //
mysql> call depart3(1);
+------+------+--------+
| id | name | depart |
+------+------+--------+
| 1 | aaa | IT |
+------+------+--------+
1 row in set (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
mysql> call depart3(2); //调用成功
+------+------+--------+
| id | name | depart |
+------+------+--------+
| 2 | bbb | HR |
+------+------+--------+
1 row in set (0.00 sec)
演示while
mysql> DELIMITER //
mysql> CREATE PROCEDURE sp_sum(
-> IN p_num INT,
-> OUT res INT)
-> BEGIN
-> SET res=1;
-> WHILE p_num > 1 DO
-> SET res=res * p_num;
-> SET p_num=p_num - 1;
-> END WHILE;
-> END
-> //
Query OK, 0 rows affected (0.00 sec)
mysql> DELIMITER ;
mysql> CALL sp_sum(5,@res);
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT @res; //演示成功
+------+
| @res |
+------+
| 120 |
+------+
1 row in set (0.00 sec)
演示repeat
mysql> DELIMITER //
mysql> CREATE PROCEDURE sp_sum2(
-> IN p_num INT,
-> OUT res INT)
-> BEGIN
-> SET res = 1;
-> REPEAT
-> SET res=res * p_num;
-> SET p_num=p_sum - 1;
-> UNTIL p_num < 2 END REPEAT;
-> END
-> //
mysql> CALL sp_sum2(5,@res);
Query OK, 0 rows affected (0.00 sec) //调用成功
mysql> SELECT @res;
+------+
| @res |
+------+
| 120 |
+------+
1 row in set (0.00 sec)
- MySql存储过程简单实例
转自:http://www.cnblogs.com/zhuawang/p/4185302.html ********************* 创建表 ************************ ...
- mysql存储过程的学习(mysql提高执行效率之进阶过程)
1:存储过程: 答:存储过程是sql语句和控制语句的预编译集合,以一个名称存储并作为一个单元处理:存储过程存储在数据库内,可以由应用程序调用执行,而且允许用户声明变量以及进行流程控制,存储类型可以接受 ...
- mysql 存储过程简单实例
一.什么是存储过程 存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程 ...
- mysql存储过程简单例子
1.之前经常在oracle数据库中使用存储过程,换到mysql后用的不多,但是有时候也用,大致记录一下,基本和oracle的一样. CREATE DEFINER = `root`@`%` PROCED ...
- Mysql存储过程简单应用
因为很久没写过存储过程了,语法也不记得了,靠百度后,解决了当前问题,这里就简单记录一下. CREATE PROCEDURE pro1() BEGIN DECLARE i int; DECLARE db ...
- mysql存储过程简单用法
show procedure status 查看所有存储过程 <!-- 简单存储过程 --> 先将结束符改成// delimiter // create procedure query ...
- mysql存储过程的学习
平时在工作中写过很多存储过程,但有时候对某些存储过程还是有些困惑的,所以发一篇文章记录下. 标准存储过程写法 create procedure`myQueryTask`( IN Task_No VAR ...
- MySql 存储过程实例(附完整注释)
将下面的语句复制粘贴可以一次性执行完,我已经测试过,没有问题! MySql存储过程简单实例: ...
- 创建MySQL存储过程示例
创建MySQL存储过程是学习MySQL数据库必须要掌握的知识,下文对创建MySQL存储过程作了详细的介绍,供您参考学习. AD:2013大数据全球技术峰会课程PPT下载 下文将教您如何创建MySQL存 ...
随机推荐
- 使用CGLib完成代理模式遇到的错误
错误堆栈信息: Exception in thread "main" java.lang.NoClassDefFoundError: org/objectweb/asm/Type ...
- CUDA Samples: Streams' usage
以下CUDA sample是分别用C++和CUDA实现的流的使用code,并对其中使用到的CUDA函数进行了解说,code参考了<GPU高性能编程CUDA实战>一书的第十章,各个文件内容如 ...
- .Net快速获取网络文本文件最后一段文字-小应用
场景 现在公司的测试环境一些文本日志不让接触,提供一个网络http服务器让人直接访问,这文件大时,一般10MB一个文件,不在同一局域网,网速限制200K,要等很久,访问很慢. .Net代码请求文本文件 ...
- 如何使用fiddller跟踪windows进程发送的请求20140911
总结点:如何使用fiddller跟踪windows进程发送的请求 案例如下: 需求:运维工具提出需求,对每个插件的配置文件,同步到运维中心时先加密,然后传输到运维中心解密,存储到数据库 测试分析:这个 ...
- zookeeper 学习命令
ls /TianheSoft/nodesls /TianheSoft/nodes/localhost_2181-0000000000ls /TianheSoft/propsls /TianheSoft ...
- 2018秋C语言程序设计(初级)作业- 第3次作业
7-1 找出最小值 #include<stdio.h> int main() { int min,i,n,count; scanf("%d",&n); for( ...
- Vue Devtools--vue调式工具
当浏览器控制台出现:Download the Vue Devtools extension for a better development experience: 1:安装 地址:https://g ...
- 一步步搭建自己的web服务器
IIS或者其他Web服务器究竟做了哪些工作,让浏览器请求一个URL地址后显示一个漂亮的网页?要想弄清这个疑问,我想我们可以自己写一个简单的web服务器. 思路: 创建socket监听浏览器请求. 连接 ...
- ios PageControl and UIScrollView
// // AlbumViewController.m // HwangKop08.18 // // Created by rimi on 15/8/20. // Copyright (c) ...
- bzoj 4852 炸弹攻击
bzoj 4852 炸弹攻击 二维平面上的最优解问题,模拟退火是一个较为优秀的近似算法. 此题确定圆心后,便可 \(O(m)\) 算出收益,且最优解附近显然也较优,是连续变化的,可以直接模拟退火. 小 ...