博客
关于我
mysql存储过程详解
阅读量:798 次
发布时间: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长事务
    查看>>
    mysql问题记录
    查看>>
    mysql间隙锁
    查看>>
    MySQL集群解决方案(1):MySQL数据库的集群方案
    查看>>
    MySQL集群解决方案(2):主从复制架构
    查看>>
    MySQL集群解决方案(4):负载均衡
    查看>>
    MySQL集群解决方案(5):PXC集群
    查看>>
    MySQL面试宝典
    查看>>
    WAP短信:融合传统短信和互联网的新型通信方式
    查看>>
    mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
    查看>>
    Mysql面试题精选
    查看>>
    MySQL面试题集锦
    查看>>
    mysql面试题,存储引擎InnoDB和MyISAM
    查看>>
    mysql面试题:为什么MySQL单表不能超过2000W条数据?
    查看>>
    mysql面试题:创建索引时会不会锁表?
    查看>>
    mysql面试题:高度为3的B+树可以存放多少数据?
    查看>>
    mysql颠覆实战笔记(八)--mysql的自定义异常处理怎么破
    查看>>
    mysql驱动、durid、mybatis之间的关系
    查看>>
    mysql驱动支持中文_mysql 驱动包-Go语言中文社区
    查看>>
    MySQL高可用之——keepalived+互为主从
    查看>>