首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL存储过程_MySQL创建存储过程

什么是存储过程 存储过程就是事先经过编译并存储在数据库中一段 SQL 语句集合; 为什么使用存储过程 调用存储过程可以简化应用开发人员很多工作,减少数据在数据库和应用服务器之间传输,对于提高数据处理效率是有好处...PROCEDURE [ IF EXISTS ] 存储过程名称 ; 注意点:上面创建存储过程语句在navicat或者sqlyog中没问题,但是放到命令行中执行会报错,在命令行中模式下,需要通过关键字...delimiter 指定SQL语句结束符 存储过程变量 在MySQL中,变量一般可分为分为三种类型: 系统变量、用户定义变量、局部变量; 一、系统变量 系统变量是MySQL服务器系统自身提供...很明显,不够灵活,通常来说,在实际业务中,我们更希望存储过程能够接收参数,并且返回处理结果,以便提供给后续业务逻辑使用,这就需要用到存储过程输入输出参数了; 五、存储过程输入输出参数使用 存储过程中使用到参数类型...循环语句在编程中经常被用到,常用于对批量数据进行循环处理,在mysql存储过程中,也提供了几种常用循环语句,包括:while循环,repeat循环,和loop循环; 1、while循环语句 while

22.2K21

Mysql存储过程

存储过程是为了完成特定功能SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程名字并给定参数(需要时)来调用执行。...存储过程优缺点 2.1、Mysql存储过程优点   存储过程可封装,并隐藏复杂商业逻辑。   ...2.2、Mysql存储过程缺点   存储过程,往往定制化于特定数据库上,因为支持编程语言不同。当切换到其他厂商数据库系统时,需要重写原有的存储过程。   ...  存储过程体包含了在过程调用时必须执行语句,例如:dml、ddl语句,if-then-else和while-do语句、声明变量declare语句等。   ...8、MySQL存储过程控制语句 8.1、变量作用域   内部变量在其作用域范围内享有更高优先权,当执行到 end。

6.7K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Mysql语句执行过程

    《高性能MySQL》 衡量查询开销三个指标 响应时间扫描行数 服务时间(处理这条语句真正花时间) 排队时间(等待资源,例如IO,行锁等) 扫描行数 返回行数 当删除了搜索条件列索引时,语句进行全表扫描...图二 语句处理过程 1.连接数据库 客户端发起一条Query请求,监听客户端‘连接管理模块’接收请求。 将请求转发到‘连接进/线程模块’。 调用‘用户模块’来进行授权检查。...优化过程书上介绍了很多情况,请参考书籍6.43章 执行计划 MySQL会生成一个指令树,然后通过存储引擎完成这棵树并返回结果 如图2 查询执行引擎  查询执行引擎则根据执行计划来完成整个查询。...在执行计划时,存储引擎通过调用实现接口来完成。 ?  图三 四个表表连接查询执行计划指令树 3.返回结果 如果查询可以被缓存,MySQL将结果存放到查询缓存里。...MySQL将结果集返回给客户端是一个逐步返回过程;数据库开始产生第一个结果时,就可以开始向服务器返回结果集。 使用MySQL客户端、服务器通信协议进行封包。 通过Tcp协议传输数据。

    2.6K20

    MySQLMySQL 存储过程

    MySQL 存储过程(了解) 1 什么是存储过程 MySQL 5.0 版本开始支持存储过程 存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用一种数据 库对象。...存储过程是为了完成特定功能SQL语句集,经编译创建并保存在数据库中,用户可通过 指定存储过程名字并给定参数(需要时)来调用执行。 简单理解: 存储过程其实就是一堆 SQL 语句合并。...中间加入了一些逻辑控制 2 存储过程优缺点 优点:   存储过程一旦调试完成后,就可以稳定运行,(前提是,业务需求要相对稳定,没有变化)   存储过程减少业务系统与数据库交互,降低耦合...,数据库交互更加快捷(应用服务器,与 数据库服务器不在同一个地区) 缺点:    在互联网行业中,大量使用MySQLMySQL存储过程与Oracle相比较弱,所以较少使用,并且互联网行业需求变化较快也是原因之一...语法格式 DELIMITER $$ -- 声明语句结束符,可以自定义 一般使用$$ CREATE PROCEDURE 过程名称() -- 声明存储过程 BEGIN -- 开始编写存储过程 -- 要执行操作

    16.1K10

    MySQL 存储过程

    1.1 简介 1.1.1 概述   MySQL 5.0 版本开始支持存储过程存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用一种数据库对象。...存储过程是为了完成特定功能 SQL 语句集,经编译创建并保存在数据库中,用户可通过指定存储过程名字并给定参数(需要时)来调用执行。...存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。 ? 1.1.2 优缺点 ☞ 优点  ① 存储过程可封装,并隐藏复杂商业逻辑。  ...④ 存储过程可以用在数据检验,强制实行商业逻辑等。 ☞ 缺点  ① 存储过程,往往定制化于特定数据库上,因为支持编程语言不同。当切换到其他数据库系统时,需要重写原有的存储过程。  ...调用时用 call,一般用于执行比较复杂过程体、更新、创建等语句

    13.4K31

    MySQL 存储过程

    存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能SQL 语句集,它存储在数据库中,一次编译后永久有效,用户通过指定存储过程名字并给出参数(如果该存储过程带有参数...存储过程是在数据库系统中,一组为了完成特定功能SQL 语句集。存储过程存储在数据库中,一次编译后,到处运行。不需要再次编译,用户通过指定存储过程名字并传递参数(如果该存储过程带有参数)来执行。...1.2、存储过程特点 用来完成较复杂业务 比较灵活,易修改,好编写,可编程性强 编写好存储过程可重复使用 1.3、存储过程优缺点 优点 存储过程在创建时候直接编译,sql语句每次使用都要编译,效率高...存储过程可以被重复使用。 存储过程只连接一次数据库,sql语句在访问多张表时,连接多次数据库。 存储程序是安全存储过程应用程序授予适当权限。...3.1、in 表示该参数值必须在调用存储过程事指定,如果不显示指定为in,那么默认就是in类型。

    37.2K20

    MySQL存储过程

    一、存储过程 1-1、含义:一组预先编译好SQL语句集合,理解成批处理语句 1、提高代码重用性 2、简化操作 3、减少了编译次数并且减少了和数据库服务器连接次数,提高了效率 好处: 1、提高代码重用性...2、简化操作 1-2、语法: CREATE PROCEDURE 存储过程名(参数列表) BEGIN 存储过程体(一组合法SQL语句) END 注意: 1、参数列表包含三部分 参数模式 参数名...,begin end可以省略 存储过程体中每条sql语句结尾要求必须加分号。...存储过程结尾可以使用 delimiter 重新设置 语法: delimiter 结束标记 案例: delimiter $ 二、存储过程创建和使用语法 2-1、语法 CALL 存储过程名(实参列表);...语法:drop procedure 存储过程名 DROP PROCEDURE p1; #错误演示,不支持批量删除 DROP PROCEDURE p2,p3 四、查看存储过程信息 语法:show

    8.8K10

    MySQL存储过程

    存储过程简介 SQL语句需要先编译然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能SQL语句集,经编译后存储在数据库中,用户通过指定存储过程名字并给定参数(如果该存储过程带有参数...MySQL存储过程 存储过程是数据库一个重要功能,MySQL 5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣。...MySQL存储过程参数用在存储过程定义,共有三种参数类型,IN,OUT,INOUT: IN参数值必须在调用存储过程时指定,在存储过程中修改该参数值不能被返回,为默认值 OUT:该值可在存储过程内部被改变...数据库.存储过程名; MySQL存储过程修改 ALTER PROCEDURE 更改用CREATE PROCEDURE 建立预先指定存储过程,其不会影响相关存储过程存储功能。...MySQL存储过程控制语句 变量作用域 内部变量在其作用域范围内享有更高优先权,当执行到end时,内部变量消失,不再可见了,在存储 过程外再也找不到这个内部变量,但是可以通过out参数或者将其值指派给会话变量来保存其值

    13.7K30

    MySQL存储过程

    文章目录 创建/调用存储过程 存储过程体 为语句块贴标签 参数列表 存储过程优缺点 存储过程优点 存储过程缺点 存储过程和函数可以理解为一段sql集合,他们被事先编译好并且存储在数据库中。...创建/调用存储过程 create procedure 存储过程名(参数列表) begin 存储过程体 end 例如: delimiter $$  #将语句结束符号从分号;临时改为两个$$(可以是自定义...(); 存储过程存储过程体包含了在过程调用时必须执行语句,例如:dml、ddl语句,if-then-else和while-do语句、声明变量declare语句等。...存储过程优缺点 存储过程优点 1.第一点优势就是执行速度快,因为我们每个sql语句执行都需要经过编译,然后在运行,但是存储过程都是直接编译好了之后直接运行即可 2.第二点优势就是减少网络流量,我们传输一个存储过程比我们传输大量...sql语句开销要小多 3.第三点就是提高系统安全性,因为存储过程可以使用权限控制,而且参数化存储过程可以有效放置slq注入攻击,保证了其安全性 4.第四点就是耦合性降低,当我们表结构发生变化之后

    10.1K30

    MySQLMySQL存储过程(1)

    目录 什么是存储过程 有哪些特性 入门案例 MySQL操作-变量定义 存储过程传参-in 存储过程传参-out 存储过程传参-inout 存储过程传参-in,out, inout 什么是存储过程 MySQL...简单说,存储过程就是一组SQL语句集,功能强大,可以 实现一些比较复杂逻辑功能,类似于JAVA语言中方法; 存储过就是数据库 SQL 语言层面的 代码封装与重用。...有哪些特性 有输入输出参数,可以声明变量,有if/else, case,while等控制语句,通过编写存储过程,可以实现 复杂逻辑功能; 函数普遍特性:模块化,封装,代码复用; 速度快,只有首次执行需经过编...call proc02(); 操作 MySQL 中还可以使用 SELECT..INTO 语句为变量赋值。...注意:当将查询结果赋值给变量时,该查询语句返回结果只能是单行单列。 MySQL 中还可以使用 SELECT..INTO 语句为变量赋值。

    1.8K20

    mysql存储过程

    1、存储过程 1)“存储过程和函数”:类似于java中方法,python中函数。...注意:每执行一句sql语句,就会连接mysql服务器一次。 3)“存储过程含义”:一组预先编译好sQL语句集合。...2、存储过程使用相关知识点 1)创建语法 create procedure 存储过程名(参数列表) begin 存储过程体(一组合法有效sql语句) end -- 如果【存储过程体】仅仅只有一句话...3)delimiter定义存储过程结束标记   在mysql语句中,由于每一个语句后面必须要;结尾,而存储过程也需要一个符号结尾,为了防止混淆,我们需要在创建存储过程之前,先使用delimiter定义一个存储过程结束标记...同时,当我们使用delimiter定义了新结束标记后,只要是没有关闭当前窗口,之后写sql语句,就都需要用这个新结束标记,作为sql语句结束标记。

    11.7K10

    MySQL存储过程

    目录: 存储过程创建 概念 优点 创建 存储过程调用 存储过程演示 删除存储过程 查看存储过程 修改存储过程 存储过程创建 存储过程概念 存储过程是一组已经预先编译好SQL...语句集合,可以理解为批处理语句(增加流程控制语句),一般在复杂业务逻辑中才会使用存储过程。...存储过程创建 语法: delimiter $ create procedure 存储过程名称(参数列表) begin 局部变量定义 多条SQL语句 流程控制语句 end;$ 注意:如果存储过程中只有一条...存储过程调用 语法: call 存储过程名称(实参列表); 注意:实参列表中包含有输出类型参数 代码实例: call pro_insert(); 当调用这个存储过程,会把创建成功创建过程语句执行一遍...存储过程名称; 查看存储过程 语法: show create procedure 存储过程名称; 修改存储过程 目前,MySQL还不提供对已存在存储过程代码修改。

    11.8K10

    MySQL存储过程

    项目中需要一个脚本,需要在MySQL 中判断表索引是否存在,不存在则创建。 本以为MySQL存在以下语句能够完成上面的功能,但是没有。...MySQL目前并不支持在SQL语句中存在流控制语句,例如上面的IF NOT EXISTS THEN END IF;让人痛心疾首。但是我们可以使用存储过程完成上面要求功能。...image.png (5)还有一个很苛刻地方就是,MySQL存储过程不能写在同一行。...(2) set定义会话变量时候,必须显示指明变量初值,且以@开头。declare定义局部变量时无需显示指明变量初值,后面可由set和select into进行赋值。...,删除等相关命令,与数据表操作语句很相似,举例如下: --查看当前数据库存储过程 show procedure status; --查看存储过程创建语句(\G表示以列形式展示结果) show create

    11.3K10

    MySQL存储过程

    文章目录 为什么使用存储过程 书写基本格式 关于参数 存储过程中开启事务 返回多个结果集 设置变量 存储过程:一段SQL语句集合 为什么使用存储过程 1、解耦合。...几十上百个字节命令压缩成十几个字节,更不需要多次发送。可能一项业务,需要先插入、再修改、再删除、再查询返回结果,本来四条命令,谁来写先不说,这四条命令哪条单拎出来不比一条存储过程调用命令长。...我们每个SQL语句执行都需要经过编译,然后再运行。但是存储过程只需要一次编译,多次运行。 4、提高系统安全性。存储过程可以使用权限控制,而且参数化存储过程可以有效防止注入攻击,保证了其安全性。...书写基本格式 create procedure 存储过程名(参数列表) begin 存储过程体 end 示例: delimiter $  #将语句结束符号从分号;临时改为$(可以是自定义) create...into User(pwd,phone,money) values(pwd_,phone_num_,0); select max(id_) from User; end$ delimiter ;  #将语句结束符号恢复为分号

    7.9K30

    mysql存储过程

    CONCAT(person_no,"号犯人住", i , "号床位"); ---字符串拼接 存储过程创建标准 DELIMITER $$ -- 定义语句结束符 为$$ DROP PROCEDURE IF...INTO [@PART](https://my.oschina.net/u/857680); -- 将提取结果带入游标 CLOSE LOOP_T; -- 关闭游标 在MySQL存储过程中经常会看到这句话...SQL SECURITY DEFINER:表示执行存储过程程序是由创建该存储过程用户权限来执行。...SQL SECURITY INVOKER:表示执行存储过程程序是由调用该存储过程用户权限来执行。...存储方法 存储方法与存储过程区别 1,存储方法参数列表只允许IN类型参数,而且没必要也不允许指定IN关键字 2,存储方法返回一个单一值,值类型在存储方法头部定义 3,存储方法可以在SQL语句内部调用

    8.2K10

    MySQL 存储过程

    存储过程是为了完成特定功能 SQL 语句集,提供许多过程语言功能,例如变量定义、条件语句、循环语句、游标以及异常处理等。...存储过程思想上很简单,就是数据库 SQL 语句封装与重用。 MySQL 5.0 版本引入了对存储过程存储函数和触发器等存储程序支持。...2.优缺点 存储过程是一组可以存储在服务器中 SQL 语句。一旦这样做了,客户端就不需要重新发出单个语句,而是可以引用存储过程。 使用存储过程在某些场景下有很多好处。...proc_parameter 为存储过程参数,使用 IN(输入)、OUT(输出)或 INOUT(输入输出)修饰。如果不显示指定,缺省为 IN。...7.删除存储过程 MySQL 使用 DROP PROCEDURE 语句可以删除存储过程

    32120
    领券