转载地址: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. Windows下MongoDB安装与PHP扩展

    MongoDB是什么就不再累述了,下面只写MongoDB安装与PHP扩展的方法. 一,安装准备 MongoDB 如果网速慢,可以到MongoDB中文社区的百度网盘下载,密码3gun.(根据你的操作系统 ...

  2. iOS8中用UIVisualEffectView实现高斯模糊视图(毛玻璃效果)

    UIBlurEffect *beffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark]; UIVisualEffectView *vi ...

  3. Leetcode: Lexicographical Numbers

    Given an integer n, return 1 - n in lexicographical order. For example, given 13, return: [1,10,11,1 ...

  4. Lintcode: Expression Evaluation (Basic Calculator III)

    Given an expression string array, return the final result of this expression Have you met this quest ...

  5. Mac 下 FlashBuilder的快捷键

    Option + 上/下  当前行上下调整位置 Shift + Command + 左/右  选择当前行 Option + Command + 左/右 查看上一个类

  6. RMQ求区间最值 nlog(n)

    转载于:http://blog.csdn.net/xuzengqiang/article/details/7350465 RMQ算法全称为(Range Minimum/Maximum Query)意思 ...

  7. [原创]java WEB学习笔记82:Hibernate学习之路---映射 一对多关联关系,配置,CRUD方法测试及注意点

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  8. eclipse中修改maven仓储

    1.找到maven的setting文件,修改setting文件: 2.打开eclipce,window->Preference->maven->user Setting

  9. 封装自己的smartyBC类

    <?php/** * Project:     Smarty: the PHP compiling template engine * File:        SmartyBC.class.p ...

  10. Hibernate反转维护

    //反转维护 @Test public void test4(){ Session ses=new Configuration().configure().buildSessionFactory(). ...