MYSQL入门学习之十二:存储过程的基本操作

本文详细介绍了MySQL存储过程的概念、优势、基本操作方法,包括创建、执行、删除存储过程,以及如何利用存储过程参数增强功能。通过实例演示了存储过程的创建与调用流程,强调了其在简化复杂操作、确保数据完整性和提高性能方面的应用价值。
        存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批文件,虽然它们的作用不仅限于批处理。
        使用存储过程需要MySQL5及以后的版本支持。
一、为什么要使用存储过程
        通过把处理封闭在容易使用的单元中,简化复杂的操作;
        将一系列处理步骤放到同一存储过程中,保证了数据的完整性和操作的安全性;
        简化对变更的管理;
        提高性能。使用存储过程比使用单独的SQL语句要快;
        存在一些只能用在单个请求中的MySQL元素和特性,存储过程可以使用它们来编写功能更强更灵活的代码;
二、基本操作
1、创建存储过程
        CREATE PROCEDURE sp_name ([proc_parameter[,...]])
            [characteristic ...] routine_body
            proc_parameter:
            [ IN | OUT | INOUT ] param_name type
        示例:
mysql>create procedure sp_test()
    ->begin
    ->    select userid,username from newname where userid=215;
    ->end
    ->//

2、执行存储过程
        CALL sp_name;
        示例:
        mysql> call sp_test();
        +--------+----------+
        | userid | username |
        +--------+----------+
        |    215 | NULL     |
        +--------+----------+

3、删除存储过程
        DROP PROCEDURE [ IF EXISTS ] sp_name;
        示例:
        mysql> drop procedure if exists sp_test;

4、查看存储过程创建信息
        SHOW CREATE PROCEDURE sp_name;
        示例:
        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 '' ];
        示例:
        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               |
        +------+---------+-----------+----------------+---------------------+---------------------+---------------+---------+----------------------+-

6、使用存储过程参数
        示例:
        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 |
        +------+

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值