转载地址: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. Java基础之处理事件——使窗口处理自己的事件(Skethcer 1 handing its own closing event)

    控制台程序. 为表示事件的常量使用标识符可以直接启用组件对象的特定事件组.调用组件的enableEvent()方法,并把想要启用事件的标识符传送为参数,但这只在不使用监视器的情况下有效.注册监听器会自 ...

  2. 从零开始攻略PHP(9)——错误和异常处理

    1.Exception类 这个类是PHP为异常处理提供的内置类.构造函数的两个参数分别是错误消息和错误代码. 除了构造函数之外,该类还提供了如下的内置方法: · getCode() 返回传递给构造函数 ...

  3. [翻译]java nio 概述

    原文地址:http://tutorials.jenkov.com/java-nio/overview.html java NIO 包含一下核心内容: Channels Buffers Selector ...

  4. IntelliJ IDEA 编译方式介绍

    编译方式介绍 相比较于 Eclipse 的实时自动编译,IntelliJ IDEA 的编译更加手动化,虽然 IntelliJ IDEA 也支持通过设置开启实时编译,但是不建议,因为太占资源了.Inte ...

  5. UltraEdit常用配置&搭建Java/C开发环境

    一:个人使用UE期间总结了以下经常使用的配置 1.手动配置语法高亮 [高级]->[配置]->[编辑器显示]->[语法高亮]->[词语列表的完整路径]->[浏览]找到安装目 ...

  6. [转]有哪些值得关注的技术博客(Java篇)

    有哪些值得关注的技术博客(Java篇)   大部分程序员在自学的道路上不知道走了多少坑,这个视频那个网站搞得自己晕头转向.对我个人来说我平常在学习的过程中喜欢看一些教程式的博客.这些博客的特点: 1. ...

  7. 大数据Spark超经典视频链接全集

    论坛贴吧等信息发布参考模板 Scala.Spark史上最全面.最详细.最彻底的一整套视频全集(特别是机器学习.Spark Core解密.Spark性能优化.Spark面试宝典.Spark项目案例等). ...

  8. Java基础(61):Java单步调试(转)

    Eclipse 的单步调试 1.设置断点在程序里面放置一个断点,也就是双击需要放置断点的程序左边的栏目上. 2.调试(1)点击"打开透视图"按钮,选择调试透视图,则打开调试透视图界 ...

  9. C#: 自定义控件

    (一)复合控件 http://wenku.baidu.com/link?url=y4BdtX3mOer4Hdin019jJpXJLi-2_ehmEo7i08cxEp1OR_3gb5CqaHrnNEB2 ...

  10. 手机端 zepto tap事件穿透

    什么是事件穿透? 点击上面的一层时会触发下面一层的事件 ”google”说原因是“tap事件实际上是在冒泡到body上时才触发”,也就是Zepto的tap事件是绑定在document上的,所以会导致 ...