博客
关于我
mysql存储过程详解
阅读量:789 次
发布时间:2023-02-12

本文共 1130 字,大约阅读时间需要 3 分钟。

MySQL存储过程详解

存储过程简介

存储过程是一组SQL语句的集合,经编译后存储在数据库中。用户通过指定存储过程名称并提供参数(如有需)来调用执行。它可以看作是一种模拟面向对象方法的工具,用于封装复杂操作或提高性能。

存储过程优势

  • 灵活性:支持流控制语句,适合复杂操作。
  • 可重用:创建后可多次调用,无需重复代码。
  • 性能优化:预编译后优化,执行速度更快。
  • 减少网络流量:传输仅调用语句。
  • 安全机制:通过权限控制数据访问。
  • MySQL存储过程创建

    创建格式

    CREATE PROCEDURE [过程名]([过程参数[,...]]) [特性...] {语句}

    示例:

    DELIMITER //CREATE PROCEDURE proc1(OUT s INT)BEGIN    SELECT COUNT(*) INTO s FROM user;END//DELIMITER ;

    分割符设置

    • 使用DELIMITER //DELIMITER ;设定存储过程的分隔符。
    • ;为默认分隔符,需前置处理以避免误解。

    参数类型

    • IN:输入参数,不能修改。
    • OUT:输出参数,可修改并返回。
    • INOUT:输入输出参数,可读写。

    变量使用

    定义变量

    DECLARE var_name [DEFAULT value] type;

    变量赋值

    SET var = expression;

    用户变量

    @var_name

    注释

    • 使用--行注释。
    • 使用/* */多行注释。

    存储过程调用

    • 使用CALL语句调用存储过程。
    • 示例:
    CALL proc_name([参数值[,...]]);

    存储过程查询

    • 查看存储过程列表:

      SELECT name FROM mysql.proc WHERE db='数据库名';
    • 查看存储过程详细:

      SHOW CREATE PROCEDURE 数据库.存储过程名;

    存储过程修改与删除

    • 修改存储过程:

      ALTER PROCEDURE proc_name;
    • 删除存储过程:

      DROP PROCEDURE proc_name;

    控制语句

    条件语句

    IF condition THEN    [操作]ELSE    [操作]END IF;

    循环语句

    REPEAT    [操作]UNTIL condition;END REPEAT;

    标签使用

    LABEL: label_name;[操作]

    基本函数

    字符函数

    • CONCATSUBSTRINGTRIM等。

    数学函数

    • ROUNDFLOORCEILING等。

    日期时间函数

    • DATE_FORMATNOWTIME_TO_SEC等。

    通过以上方法,开发者可以充分利用MySQL存储过程的优势,提升数据库性能和开发效率。

    转载地址:http://vrbfk.baihongyu.com/

    你可能感兴趣的文章
    Mysql学习总结(18)——Mysql主从架构的复制原理及配置详解
    查看>>
    Mysql学习总结(19)——Mysql无法创建外键的原因
    查看>>
    Mysql学习总结(19)——Mysql无法创建外键的原因
    查看>>
    Mysql学习总结(1)——常用sql语句汇总
    查看>>
    Mysql学习总结(20)——MySQL数据库优化的最佳实践
    查看>>
    Mysql学习总结(21)——MySQL数据库常见面试题
    查看>>
    Mysql学习总结(22)——Mysql数据库中制作千万级测试表
    查看>>
    Mysql学习总结(23)——MySQL统计函数和分组查询
    查看>>
    Mysql学习总结(24)——MySQL多表查询合并结果和内连接查询
    查看>>
    Mysql学习总结(25)——MySQL外连接查询
    查看>>
    Mysql学习总结(26)——MySQL子查询
    查看>>
    Mysql学习总结(27)——Mysql数据库字符串函数
    查看>>
    Mysql学习总结(28)——MySQL建表规范与常见问题
    查看>>
    Mysql学习总结(29)——MySQL中CHAR和VARCHAR
    查看>>
    Mysql学习总结(2)——Mysql超详细Window安装教程
    查看>>
    Mysql学习总结(30)——MySQL 索引详解大全
    查看>>
    Mysql学习总结(31)——MySql使用建议,尽量避免这些问题
    查看>>
    Mysql学习总结(32)——MySQL分页技术详解
    查看>>
    Mysql学习总结(33)——阿里云centos配置MySQL主从复制
    查看>>
    Mysql学习总结(35)——Mysql两千万数据优化及迁移
    查看>>