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

    你可能感兴趣的文章
    Vue过滤器_使用过滤器进行数据格式化操作---vue工作笔记0015
    查看>>
    Ncast盈可视 高清智能录播系统 IPSetup.php信息泄露+RCE漏洞复现(CVE-2024-0305)
    查看>>
    NCNN中的模型量化解决方案:源码阅读和原理解析
    查看>>
    NCNN源码学习(1):Mat详解
    查看>>
    nc命令详解
    查看>>
    NC综合漏洞利用工具
    查看>>
    ndarray 比 recarray 访问快吗?
    查看>>
    ndk-cmake
    查看>>
    NdkBootPicker 使用与安装指南
    查看>>
    ndk特定版本下载
    查看>>
    NDK编译错误expected specifier-qualifier-list before...
    查看>>
    Neat Stuff to Do in List Controls Using Custom Draw
    查看>>
    Necurs僵尸网络攻击美国金融机构 利用Trickbot银行木马窃取账户信息和欺诈
    查看>>
    Needle in a haystack: efficient storage of billions of photos 【转】
    查看>>
    NeHe OpenGL教程 07 纹理过滤、应用光照
    查看>>
    NeHe OpenGL教程 第四十四课:3D光晕
    查看>>
    Neighbor2Neighbor 开源项目教程
    查看>>
    neo4j图形数据库Java应用
    查看>>
    Neo4j图数据库_web页面关闭登录实现免登陆访问_常用的cypher语句_删除_查询_创建关系图谱---Neo4j图数据库工作笔记0013
    查看>>
    Neo4j图数据库的介绍_图数据库结构_节点_关系_属性_数据---Neo4j图数据库工作笔记0001
    查看>>