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

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

如果将这些sql操作封装在存储过程中,只需网络交互一次可能就可以了; 存储过程基础语法 1、创建存储过程语法 CREATE PROCEDURE 存储过程名称 ([ 参数列表 ]) BEGIN --...PROCEDURE [ IF EXISTS ] 存储过程名称 ; 注意点:上面创建存储过程的语句在navicat或者sqlyog中没问题,但是放到命令行中执行会报错,在命令行中模式下,需要通过关键字...delimiter 指定SQL语句的结束符 存储过程中的变量 在MySQL中,变量一般可分为分为三种类型: 系统变量、用户定义变量、局部变量; 一、系统变量 系统变量是MySQL服务器系统自身提供的...END WHILE; 先判定条件,如果条件为true,则执行逻辑,否则,不执行逻辑 需求:从1累加到N,并求出累加的结果 create procedure p6(in n int) begin...UNTIL 条件 END REPEAT; 先执行一次逻辑,然后判定UNTIL条件是否满足,如果满足,则退出。

22.3K21

mysql技巧:如果记录存在则更新如果不存在则插入的三种处理方法

要求: 新增一个员工时,如果该员工已存在(以员工号f_emp_code作为判断依据),则更新,否则插入。而且工资f_salary,更新时,不得低于原工资(即:工资只能涨,不能降)。...10007' , '新人' , '西安' , IF(1000 > f_salary , 1000 , f_salary)); replace into相当于,先检测该记录是否存在(根据表上的唯一键),如果存在...这个方法有一个很大的问题,如果记录存在,每次执行完,主键自增id就变了(相当于重新insert了一条),对于有复杂关联的业务场景,如果主表的id变了,其它子表没做好同步,会死得很难看。...但是有另外一个问题,如果这个表上有不止一个唯一约束,在特定版本的mysql中容易产生dead lock(死锁),见网友文章https://blog.csdn.net/pml18710973036/article

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

    mysql存储过程----创建

    存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。...存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。 优点 存储过程可封装,并隐藏复杂的商业逻辑。 存储过程可以回传值,并可以接受参数。...修改sql结束符号: 关键字delimiter ,下面语句代表将结束符号;修改为// delimiter // 删除存储过程: 关键字DROP PROCEDURE,下面语句意思,如果存在存储过程名字是...pro_test的,则删除该存储过程。...DROP PROCEDURE IF EXISTS pro_test// 创建存储过程: 关键字CREATE PROCEDURE,下面语句意思,创建名为pro_test的存储过程 CREATE PROCEDURE

    1.9K20

    mysql存储过程实例_sql存储过程创建实例详解

    (如果该存储过程带有参数)来调用执行它。...如果某一操作包含大量的Transaction-SQL代码或分别被多次执行,那么存储过程要比批处理的执行速度快很多。因为存储过程是预编译的。...好在MySQL 5.0终于开始已经支持存储过程,这样即可以大大提高数据库的处理速度,同时也可以提高数据库编程的灵活性。 3. MySQL存储过程的创建 (1)....格式 MySQL存储过程创建的格式:CREATE PROCEDURE 过程名 ([过程参数[,…]]) [特性 …] 过程体 这里先举个例子: mysql> DELIMITER //...,因为MySQL默认以“;”为分隔符,如果我们没有声明分割符,那么编译器会把存储过程当成SQL语句进行处理,则存储过程的编译过程会报错,所以要事先用DELIMITER关键字申明当前段分隔符,这样MySQL

    2.3K20

    MySQL存储过程创建与使用

    如果表名、列名或业务逻辑(或别的内容)有变化,只需要更改存储过程的代码。使用它的人员甚至不需要知道这些变化 3.存储过程应该怎么使用呢?...查看创建好的存储过程 show procedure status; 删除存储过程 DROP PROCEDURE 存储过程名称; ?...3.2.创建带参数(OUT)存储过程的语法及使用 带参数传递的存储过程语法如下,其中OUT表示的是返回的值,也就是后面在调用存储过程时如果选择的参数就会返回对应的结果,OUT相当于声明参数的格式一样...3.3.创建带参数(OUT和IN)存储过程的语法及使用 带参数传递的存储过程语法如下,其中OUT表示的是返回的值,也就是后面在调用存储过程时如果选择的参数就会返回对应的结果,OUT相当于声明参数的格式一样...,现在业务需求是通过传入一个布尔值和对应的主键Id,如果为真(不是0就为真)就查询出对应主键的年龄并乘以10,如果为假(为0既假)就查询出对应主键的年龄并乘以100,现在用存储过程怎么写呢?

    2K30

    mysql创建定时执行存储过程任务

    Records of test_sche -- ---------------------------- INSERT INTO `test_sche` VALUES ('1', '188'); 2.创建一个存储过程...UPDATE test_sche SET counts=counts+1 WHERE id=1; END 注意,创建存储过程的时候,如果采用命令行的方式,需要先修改命令结束符,将分号改成其他的符号 --...设置分隔符为 '$$' ,mysql默认的语句分隔符为 ';' ,这样在后续的 create 到 end 这段代码都会看成是一条语句来执行 DELIMITER $$ //创建存储过程或者事件语句...如果想要查看事件运行情况: 3.2查看事件运行状态 select * from mysql.event 3.3开启或者关闭事件 ALTER EVENT test_sche_event DISABLE...这里采用Navicat for mysql: 4.1创建存储过程 ? 4.2创建事件 ? ?

    5K70

    MySQL存储过程的创建及调用

    阅读目录:MySQL存储过程_创建-调用-参数 存储过程:SQL中的“脚本”     1.创建存储过程     2.调用存储过程     3.存储过程体     4.语句块标签 存储过程的参数...一组可编程的函数,是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。...一、存储过程的创建和调用   >存储过程就是具有名字的一段代码,用来完成一个特定的功能。   >创建的存储过程保存在数据库的数据字典中。...from TENNIS.PLAYERS; mysql> create table MATCHES as select * from TENNIS.MATCHES; 示例:创建一个存储过程,删除给定球员参加的所有比赛...> delimiter ;  #将语句的结束符号恢复为分号 解析:   默认情况下,存储过程和默认数据库相关联,如果想指定存储过程创建在某个特定的数据库下,那么在过程名前面加数据库名做前缀;   在定义过程时

    2.9K20

    记录不存在则插入,存在则更新 → MySQL 的实现方式有哪些?

    ,不存在则执行插入   针对这个需求,我们有哪些实现方式?...,碰到 不存在则插入,存在则更新 的需求时,第一时间往往想到的是 REPLACE INTO   工作原理 replace into 跟 insert 功能类似   不同点在于: replace into...首先尝试插入数据到表中,如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据,否则直接插入新数据 replace 语句会返回一个数,表示受影响的行的数目,该数是被删除和被插入的行数的和...值的新纪录是插入时就会发生 duplicate key error ,每次冲突之后 AUTO_INCREMENT += 1,直到增长为 max(id) + 1 之后才能恢复正常 INSERT UPDATE   针对 不存在则插入...,存在则更新 , MySQL 还提供了另外一种方言实现: INSERT ...

    2.2K10

    创建更新存储过程

    创建/更新存储过程 基础基础用法 创建/修改无参存储过程 CREATE OR REPLACE PROCEDURE procedure_name [IS|AS] --声明全局变量(可选) BEGIN --...存储过程的执行体 END; --也可以写成 END procedure_name; 创建/修改携参数存储过程 CREATE OR REPLACE PROCEDURE procedure_name(var_name1...后面的分号 --或者 BEGIN procedure_name(); END; --注意 分号不能少,特别是END后面的分号 --或者 SQL> EXEC procedure_name; 简单的示例 创建携带参数存储过程...to_date(workDate,'yyyy-mm-dd')); END; CALL SP_TEST_PROC(sysdate); --输出:The input date is:22-AUG-24 --创建携带返回值存储过程...DECLARE length, width NUMBER(18,2) DEFAULT 10; -- 声明变量 length, width,默认值都为10 BEGIN -- do something END; 创建无参数存储过程

    2.9K50

    MySQL:MySQL 存储过程

    MySQL 存储过程(了解) 1 什么是存储过程 MySQL 5.0 版本开始支持存储过程 存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据 库对象。...存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过 指定存储过程的名字并给定参数(需要时)来调用执行。 简单理解: 存储过程其实就是一堆 SQL 语句的合并。...,数据库交互更加快捷(应用服务器,与 数据库服务器不在同一个地区) 缺点:    在互联网行业中,大量使用MySQL,MySQL的存储过程与Oracle的相比较弱,所以较少使用,并且互联网行业需求变化较快也是原因之一... 阿里的代码规范里也提出了禁止使用存储过程,存储过程维护起来的确麻烦; 3 存储过程的创建方式 方式1 1) 数据准备 创建商品表 与 订单表 # 商品表 CREATE TABLE goods(...CREATE PROCEDURE 存储过程名称(IN 参数名 参数类型) 2) 创建接收参数的存储过程 需求: 接收一个商品id, 根据id删除数据 DELIMITER $$ CREATE PROCEDURE

    16.1K10

    MySQL 存储过程

    1.1 简介 1.1.1 概述   MySQL 5.0 版本开始支持存储过程。存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据库对象。...存储过程是为了完成特定功能的 SQL 语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行。...1.2 存储过程的使用 1.2.1 创建存储过程 ☞ 语法 create procedure 存储过程名([参数模式] 参数名 参数类型) begin # 变量定义 declare name type...存储过程不能修改,只能先删除,然后重新创建 1.2.5 删除存储过程 ☞ 语法 # if exites 可以省略,但是不建议 drop procedure [if exists] 存储过程名称...调用时用 call,一般用于执行比较复杂的的过程体、更新、创建等语句。

    13.4K31

    MySQL存储过程

    文章目录 创建/调用存储过程 存储过程体 为语句块贴标签 参数列表 存储过程的优缺点 存储过程的优点 存储过程的缺点 存储过程和函数可以理解为一段sql的集合,他们被事先编译好并且存储在数据库中。...创建/调用存储过程 create procedure 存储过程名(参数列表) begin 存储过程体 end 例如: delimiter $$  #将语句的结束符号从分号;临时改为两个$$(可以是自定义...因为out是向调用者输出参数,不接收输入的参数,所以存储过程里的p_out为null +-------+ | p_out | +-------+ | 2 | +-------+ mysql>...因为存储过程是和数据库绑定的,如果我们更换数据库之类的操作,可能很多地方需要改动。 2.修改不方便。...对于小型的web应用来说,如果我们使用语句缓存,发现编译sql的开销并不大,但是使用在存储过程缺需要检查权限一类的开销,这些赘余功能也会在一定程度上拖累性能

    10.1K30
    领券