博客
关于我
mysql存储过程详解
阅读量:799 次
发布时间: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/

    你可能感兴趣的文章
    Navicat控制mysql用户权限
    查看>>
    navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
    查看>>
    Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
    查看>>
    Navicat连接mysql数据库中出现的所有问题解决方案(全)
    查看>>
    Navicat连接Oracle出现Oracle library is not loaded的解决方法
    查看>>
    Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
    查看>>
    Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
    查看>>
    navicat连接远程mysql数据库
    查看>>
    Navicat通过存储过程批量插入mysql数据
    查看>>
    Navicat(数据库可视化操作软件)安装、配置、测试
    查看>>
    navigationController
    查看>>
    NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
    查看>>
    NBear简介与使用图解
    查看>>
    Vue过滤器_使用过滤器进行数据格式化操作---vue工作笔记0015
    查看>>
    Ncast盈可视 高清智能录播系统 IPSetup.php信息泄露+RCE漏洞复现(CVE-2024-0305)
    查看>>
    NCNN中的模型量化解决方案:源码阅读和原理解析
    查看>>
    NCNN源码学习(1):Mat详解
    查看>>
    nc命令详解
    查看>>
    NC综合漏洞利用工具
    查看>>
    ndarray 比 recarray 访问快吗?
    查看>>