转载地址: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. HTML是什么

    HTML(Hyper Text Mark-up Language )即超文本标记语言,是 WWW 的描述语言,由 Tim Berners-lee提出.设计 HTML 语言的目的是为了能把存放在一台电脑 ...

  2. pip报ssl错误解决

     InsecurePlatformWarning: A true SSLContext object is not available.   # yum -y install openssl-deve ...

  3. docker offical docs:Working with Docker Images

    Working with Docker Images ##orignal is always the best In the introduction we've discovered that Do ...

  4. [c++基本语法]——构造函数初始化列表

    c++构造函数初始化成员变量列表: #pragma once class Node { public: int data; // 权值 Node *parent; // 父节点 Node *left; ...

  5. J2EE MyBatis使用

    MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .20 ...

  6. 使用Mac的AppleScritp调用控制台的方式

    使用Mac的AppleScritp调用 控制台的方法 tell application "Terminal" activate do script "cd Documen ...

  7. VCL 如何加载Gif图片和Png图片

    加上头文件#include <Vcl.Imaging.GIFImg.hpp> #include <Vcl.Imaging.pngimage.hpp> Image1->Pi ...

  8. C# 动态链接库的创建

    首先在C#工程下面安装第三方插件包 安装方法:Tools --> Library Package Manager --> Package Manager Console Install-P ...

  9. SQL 存储和触发器

    存储过程:就像函数一样的会保存在数据库中-->可编程性 --> 存储过程 创建存储过程:create proc JiaFa--需要的参数@a int,@b intas --存储过程的内容 ...

  10. paper 83:前景检测算法_1(codebook和平均背景法)

    前景分割中一个非常重要的研究方向就是背景减图法,因为背景减图的方法简单,原理容易被想到,且在智能视频监控领域中,摄像机很多情况下是固定的,且背景也是基本不变或者是缓慢变换的,在这种场合背景减图法的应用 ...