转载地址:http://www.2cto.com/database/201212/177380.html

存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批文件,虽然它们的作用不仅限于批处理。  www.2cto.com  
        使用存储过程需要MySQL5及以后的版本支持。
一、为什么要使用存储过程
        通过把处理封闭在容易使用的单元中,简化复杂的操作;
        将一系列处理步骤放到同一存储过程中,保证了数据的完整性和操作的安全性;
        简化对变更的管理;
        提高性能。使用存储过程比使用单独的SQL语句要快;
        存在一些只能用在单个请求中的MySQL元素和特性,存储过程可以使用它们来编写功能更强更灵活的代码;
二、基本操作
1、创建存储过程
        CREATE PROCEDURE sp_name ([proc_parameter[,...]])
            [characteristic ...] routine_body
            proc_parameter:
            [ IN | OUT | INOUT ] param_name type
        示例:
[sql] 
mysql>create procedure sp_test()  
    ->begin  
    ->    select userid,username from newname where userid=215;  
    ->end  
    ->//  
 
2、执行存储过程
        CALL sp_name;
        示例:
[sql] 
mysql> call sp_test();  
+--------+----------+  
| userid | username |  
+--------+----------+  
|    215 | NULL     |  
+--------+----------+  
 
3、删除存储过程
        DROP PROCEDURE [ IF EXISTS ] sp_name;
        示例:
[sql] 
mysql> drop procedure if exists sp_test;  
 
4、查看存储过程创建信息
        SHOW CREATE PROCEDURE sp_name;
        示例:
[sql] 
mysql> show create procedure sp_test;  
+-----------+----------+--------------------------------------------------------+----------------------+----------------------+--------------------+  
| Procedure | sql_mode | Create Procedure                                       | character_set_client | collation_connection | Database Collation |  
+-----------+----------+--------------------------------------------------------+----------------------+----------------------+--------------------+  
| sp_test   |          | CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_test`()  
begin  
    select userid,username from newname where userid=215;  
end | latin1               | latin1_swedish_ci    | latin1_swedish_ci  |  
+-----------+----------+--------------------------------------------------------+----------------------+----------------------+--------------------+  
 
5、查看存储过程状态
        SHOW PROCEDURE STATUS [ LIKE '' ];
        示例:
[sql] 
mysql> show procedure status like 'sp_test';  
+------+---------+-----------+----------------+---------------------+---------------------+---------------+---------+----------------------+-  
| Db   | Name    | Type      | Definer        | Modified            | Created             | Security_type | Comment | character_set_client |  
+------+---------+-----------+----------------+---------------------+---------------------+---------------+---------+----------------------+-  
| test | sp_test | PROCEDURE | root@localhost | 2012-12-17 23:57:38 | 2012-12-17 23:57:38 | DEFINER       |         | latin1               |  
+------+---------+-----------+----------------+---------------------+---------------------+---------------+---------+----------------------+-  
  www.2cto.com  
6、使用存储过程参数
        示例:
[sql] 
mysql> delimiter //  
mysql> create procedure sp_type_cnt(  
    ->     IN in_type int,  
    ->     OUT out_cnt int  
    -> )  
    -> begin  
    ->     select count(*)  
    ->     from newname  
    ->     where type = in_type  
    ->     into out_cnt;  
    -> end;  
    -> //  
mysql> delimiter ;  
mysql> call sp_type_cnt(0,@cnt);  
mysql> select @cnt;  
+------+  
| @cnt |  
+------+  
|  159 |  
+------+ 

【转】MYSQL入门学习之十二:存储过程的基本操作的更多相关文章

  1. 【转】MYSQL入门学习之十:视图的基本操作

    转载地址:http://www.2cto.com/database/201212/176775.html 一.视图的基本介绍  www.2cto.com           视图是虚拟的表.与包含数据 ...

  2. MYSQL进阶学习笔记十二:MySQL 表分区!(视频序号:进阶_29,30)

    知识点十三:MySQL 表的分区(29) 一.什么要采用分区: 分区的定义: 当数据量过大的时候(通常是指百万级或千万级数据的时候),这时候需要将一张表划分几张表存储.一些查询可以得到极大的优化,这主 ...

  3. salesforce 零基础开发入门学习(十二)with sharing 、without sharing 、无声明区别

    在salesforce中,声明类大概可以分成三类:分别是可以声明为with sharing,without sharing,以及两者均不声明. public with sharing class A ...

  4. 【转】MYSQL入门学习之十一:触发器的基本操作

    转载地址:http://www.2cto.com/database/201212/176781.html 触发器是MySQL响应以下任意语句而自动执行的一条MySQL语句(或位于BEGIN和END语句 ...

  5. [OpenCV入门教程之十二】OpenCV边缘检测:Canny算子,Sobel算子,Laplace算子,Scharr滤波器合辑

    http://blog.csdn.net/poem_qianmo/article/details/25560901 本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://blog ...

  6. python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL

    python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL实战例子:使用pyspider匹配输出带.html结尾的URL:@config(a ...

  7. Go语言学习笔记十二: 范围(Range)

    Go语言学习笔记十二: 范围(Range) rang这个关键字主要用来遍历数组,切片,通道或Map.在数组和切片中返回索引值,在Map中返回key. 这个特别像python的方式.不过写法上比较怪异使 ...

  8. 【数据库】9.0 MySQL入门学习(九)——获得数据库和表的信息、日期计算、查询、选择特殊列

    1.0 SELECT语句用来从数据表中检索信息. SELECT what_to_select FROM which_table WHERE conditions_to_satisfy; what_to ...

  9. 【数据库】7.0 MySQL入门学习(七)——MySQL基本指令:帮助、清除输入、查询等

    1.0 help == ? 帮助指令,查询某个指令的解释.用法.说明等.详情参考博文: [数据库]6.0 MySQL入门学习(六)——MySQL启动与停止.官方手册.文档查询 https://www. ...

随机推荐

  1. MS SQL SERVER 锁研究记录

    首先创建一直数据表 ChenJi,有如下字段: ID, DanWeiID,  Name,  ChenJi CREATE TABLE [dbo].[ChenJi]( [ID] [int] NOT NUL ...

  2. Postfix Completion 的使用

    Postfix Completion 的介绍 Postfix Completion 功能本质上也是代码模板,只是它比 Live Templates 来得更加便捷一点点而已.具体它是做什么的,我们通过下 ...

  3. sdutoj 2604 Thrall’s Dream

    http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2604 Thrall’s Dream Time ...

  4. zoj The 12th Zhejiang Provincial Collegiate Programming Contest May Day Holiday

    http://acm.zju.edu.cn/onlinejudge/showContestProblem.do?problemId=5500 The 12th Zhejiang Provincial ...

  5. ofbiz进击 。 ofbiz 退货流程(包含获取可退货项流程分析 以及 取消退货项的过程分析)

    根据订单获取可退货项流程分析 退货的时候,调用 services_return.xml 中的获取可进行退货的退货项  getReturnableItems  ,该服务调用了Java类 org.ofbi ...

  6. JSP数据交互习题错误总结

    1:如果注册完页面有中文字符需要在提交后的页面显示注册信息,切记先把接受到的request的编码方式改为中文:request.setCharacterEncoding("utf-8" ...

  7. bzoj4448 [Scoi2015]情报传递

    第一问不解释,对于第二问的处理,可以使用cdq分治,假设分治的询问区间是[L,R],那么我们对于标号在[L,mid]的修改操作赋予一个权值,因为在当前[L,R]中[L,mid]的修改操作只会对[mid ...

  8. 1009: 恺撒Caesar密码

    1009: 恺撒Caesar密码 时间限制: 10 Sec  内存限制: 128 MB提交: 349  解决: 215[提交][状态][讨论版] 题目描述 Julius Caesar 生活在充满危险和 ...

  9. BackgroundWorker的使用

    一个程序中需要进行大量的运算,并且需要在运算过程中支持用户一定的交互,为了获得更好的用户体验,使用BackgroundWorker来完成这一功能.   基本操作: bgw.RunWorkerAsync ...

  10. 夺命雷公狗---DEDECMS----1dedecms的安装过程

    我们这次要玩的dedecms(cms也就是内容管理系统),电商网.或者政府网..小说网.新闻网之类的都是基于可以用cms来实现的. 现在在市场上主流的cms系统有dedecms(织梦),帝国cms,p ...