MYSQL 存储过程学习

MYSQL 存储过程学习笔记

MySQL 5.0终于开始已经支持存储过程,这样即可以大大提高数据库的处理速度,同时也可以提高数据库编程的灵活性。

存储过程的优点:

①重复使用。存储过程可以重复使用,从而可以减少数据库开发人员的工作量。

②提高性能。存储过程在创建的时候在进行了编译,将来使用的时候不再重新翻译。一般的SQL语句每执行一次就需要编译一次,所以使用存储过程提高了效率。

③减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此降低了网络传输的数据量。

④安全性。参数化的存储过程可以防止SQL注入式攻击,而且可以将Grant、Deny以及Revoke权限应用于存储过程。

创建简单的事例表有id,和name两个字段,并插入5条数据如下:

mysql> create table t1(id int not null primary key,name varchar(20) default null);
mysql> insert into t1 values(1,‘name1‘),(2,‘name2‘),(3,‘name3‘),(4,‘name4‘),(5,‘name5‘);
mysql> select * from t1;
+----+-------+
| id | name  |
+----+-------+
|  1 | name1 |
|  2 | name2 |
|  3 | name3 |
|  4 | name4 |
|  5 | name5 |
+----+-------+
5 rows in set (0.00 sec)

MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT:

IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值;
OUT 输出参数:该值可在存储过程内部被改变,并可返回;
INOUT 输入输出参数:调用时指定,并且可被改变和返回。

IN参数例子:

mysql> delimiter //
mysql> create procedure p_in(IN p_id int)  
    -> begin
    -> delete from t1 where id = p_id;                                          
    -> end
    -> //
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;
mysql> call p_in(5);
Query OK, 1 row affected (0.03 sec)
mysql> select * from t1;
+----+-------+
| id | name  |
+----+-------+
|  1 | name1 |
|  2 | name2 |
|  3 | name3 |
|  4 | name4 |
+----+-------+
4 rows in set (0.00 sec)

OUT参数例子:

mysql> delimiter //
mysql> create procedure p_out(OUT p_out int)
    -> begin
    -> select count(id) from t1 into p_out;
    -> end
    -> //
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;
mysql> call p_out(@p_out_result);
Query OK, 1 row affected (0.00 sec)
mysql> select @p_out_result;
+---------------+
| @p_out_result |
+---------------+
|       4 |
+---------------+
1 row in set (0.00 sec)

同时存在IN,OUT参数:

mysql> delimiter //
mysql> create procedure p_in_out(IN p_in int,OUT p_out int)
    -> begin
    -> delete from t1 where id =p_in;
    -> select count(id) from t1 into p_out;              
    -> end
    -> //
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;
mysql> select @p_in_out_result;
+------------------+
| @p_in_out_result |
+------------------+
|        3 |
+------------------+
1 row in set (0.00 sec)
mysql> select * from t1;
+----+-------+
| id | name  |
+----+-------+
|  1 | name1 |
|  2 | name2 |
|  3 | name3 |
+----+-------+
3 rows in set (0.00 sec)

INOUT参数:

mysql> select * from t1;
+----+-------+
| id | name  |
+----+-------+
|  1 | name1 |
|  2 | name2 |
|  3 | name3 |
|  4 | name4 |
|  5 | name5 |
+----+-------+
5 rows in set (0.00 sec)
mysql> delimiter //
mysql> create procedure p_inout(INOUT p_inout int)
    ->begin
    ->select p_inout;
    ->set p_inout=4;
    ->select p_inout;
    -> delete from t1 where id =p_inout; 
    ->end
    ->//
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;
mysql> set @p_input=5;
mysql> call p_inout(@p_input);
+---------+
| p_inout |
+---------+
|    5 |
+---------+
1 row in set (0.00 sec)
+---------+
| p_inout |
+---------+
|    4 |
+---------+
1 row in set (0.00 sec)

后面继续学习在存储过程中加入流程控制语句!

时间: 2024-10-12 17:42:19

MYSQL 存储过程学习的相关文章

mysql存储过程学习笔记

1.      存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它. 一个存储过程是一个可编程的函数,它在数据库中创建并保存.它可以有SQL语句和一些特殊的控制结构组成.当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的.数据库中的存储过程可以看做

MYSQL存储过程学习

1.游标的使用 BEGIN DECLARE done INT DEFAULT 0; DECLARE userid INT; DECLARE rs CURSOR FOR SELECT `uid` FROM sinbegin_user WHERE service = 0;/*定义游标*/ DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;/*异常处理*/ OPEN rs;/*打开游标*/ FETCH NEXT FROM rs INT

mysql 5.0存储过程学习总结

mysql存储过程的创建,删除,调用及其他常用命令 本人qq群也有许多的技术文档,希望可以为你提供一些帮助(非技术的勿加). QQ群:   281442983 (点击链接加入群:http://jq.qq.com/?_wv=1027&k=29LoD19)  mysql 5.0存储过程学习总结 一.创建存储过程 1.基本语法: create procedure sp_name()begin………end 2.参数传递 二.调用存储过程 1.基本语法:call sp_name()注意:存储过程名称后面必

MYSql存储过程的作用及语法

1.使用了存过程,很多相似性的删除,更新,新增等操作就变得轻松了,并且以后也便于管理! 2.存储过程因为SQL语句已经预编绎过了,因此运行的速度比较快. 3.存储过程可以接受参数.输出参数.返回单个或多个结果集以及返回值.可以向程序返回错误原因. 4.存储过程运行比较稳定,不会有太多的错误.只要一次成功,以后都会按这个程序运行. 5.存储过程主要是在服务器上运行,减少对客户机的压力. 6.存储过程可以包含程序流.逻辑以及对数据库的查询.同时可以实体封装和隐藏了数据逻辑. 7.存储过程可以在单个存

mysql 存储过程简单学习

转载自:http://blog.chinaunix.net/uid-23302288-id-3785111.html ■存储过程Stored Procedure 存储过程就是保存一系列SQL命令的集合,将这些sql命令有组织的形成一个小程序,这样会实现很复杂的处理 SQL基本是一个命令一个命令执行,虽然可以通过连接.子查询等实现些高级的处理,但局限性是显而易见的 ■存储过程的优势 1.提高执行性能(存储过程事先完成了解析.编译的处理,执行时能减轻数据库负担) 2.可减轻网络负担(比起多次传递SQ

mysql数据库存储过程学习

1.建立存储过程方式一: mysql中存储过程属于函数一栏中,点击新建函数会有让你选择是存储过程还是函数 接下来是存储过程中设置的参数: IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值 OUT 输出参数:该值可在存储过程内部被改变,并可返回 INOUT 输入输出参数:调用时指定,并且可被改变和返回 接下来就在BEGIN和END中填写需要的sql语句,和平时使用的相同 保存后存储在函数下,执行时可以直接运行,查看结果. 注:当没有参数或者只有

MYSQL存储过程和函数学习笔记

学至Tarena金牌讲师何山,金色晨曦科技公司技术总监沙利穆课程笔记的综合. 1. 什么是存储过程和函数 将SQL语句放入一个集合里,然后直接调用存储过程和函数来执行已经定义好的SQL语句,通过存储过程和函数,可以避免开发人员重复编写相同的SQL语句. MYSQL存储过程和函数是保存在服务器中,在服务器中存储和执行,可以减少客户端和服务器端之间数据传输的消耗. 存储过程就是一组已经保存在数据库中的语句,并且可以随时地调用. 存储过程允许标准组件式编程,存储过程在被创建以后可以在程序中被多次调用而

sql学习笔记(16)----------mysql存储过程详解

mysql存储过程详解 1.     存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它. 一个存储过程是一个可编程的函数,它在数据库中创建并保存.它可以有SQL语句和一些特殊的控制结构组成.当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的.

MySQl Study学习之--MySQl二进制日志管理

MySQl Study学习之--MySQl二进制日志管理 MySQL二进制日志(Binary Log):   a.它包含的内容及作用如下:    包含了所有更新了数据或者已经潜在更新了数据(比如没有匹配任何行的一个DELETE)    包含关于每个更新数据库(DML)的语句的执行时间信息    不包含没有修改任何数据的语句,如果需要启用该选项,需要开启通用日志功能    主要目的是尽可能的将数据库恢复到数据库故障点,因为二进制日志包含备份后进行的所有更新    用于在主复制服务器上记录所有将发送