精华内容
下载资源
问答
  • mysql存储过程删除数据
    千次阅读
    2019-06-14 20:40:14

    创建存储过程:

    DELIMITER //
    CREATE PROCEDURE autodelete()
        -> BEGIN
        -> delete From amap_log where DATE(time) <= DATE(DATE_SUB(NOW(),INTERVAL 30 day));
        -> END
        -> //
    DELIMITER ;
    

    创建事件,定制每天执行autodel的存储过程:

    CREATE EVENT `event_auto_delete_amap_log`   
    ON SCHEDULE EVERY 1 DAY STARTS '2019-06-14 00:00:00'   
    ON COMPLETION NOT PRESERVE ENABLE DO CALL autodelete();  
    

    开启事件计划(调度器)4种方法。键值1或者ON表示开启;0或者OFF表示关闭:

    SET GLOBAL event_scheduler = 1;  
    SET @@global.event_scheduler = 1;  
    SET GLOBAL event_scheduler = ON;  
    SET @@global.event_scheduler = ON; 
    

    查看当前是否已开启事件计划(调度器)3种方法:

    SHOW VARIABLES LIKE 'event_scheduler';
    SELECT @@event_scheduler;
    SHOW PROCESSLIST;​
    

    事件开启与关闭:

    ALTER EVENT event_auto_delete_amap_log ON COMPLETION PRESERVE ENABLE; 
    ALTER EVENT event_auto_delete_amap_log ON COMPLETION PRESERVE DISABLE; 
    
    更多相关内容
  • Mysql 删除数据存储过程

    千次阅读 2019-07-25 21:24:00
    删除数据存储过程, 可用于定时任务, 以达到定时清理数据的需求 DROP PROCEDURE procedure_table_clean; CREATE PROCEDURE procedure_table_clean() BEGIN DECLARE no_more_record integer DEFAULT 0; ...

    删除表数据的存储过程, 可用于定时任务, 以达到定时清理数据的需求

    DROP PROCEDURE procedure_table_clean;
    CREATE PROCEDURE procedure_table_clean()
    BEGIN
        DECLARE no_more_record integer DEFAULT 0;
        DECLARE id varchar(36);
        DECLARE num integer default 0;
        DECLARE cur_record CURSOR FOR SELECT UUID FROM table_1;
    
        DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_record = 1; # 当没有记录时赋值为1
        OPEN cur_record;
        FETCH cur_record INTO id;
        WHILE no_more_record != 1 DO
    
        DELETE FROM table_1 WHERE col_id = id;
    
        IF num > 1000
        THEN
            COMMIT; SET num = 0;
        ELSE
            SET num = num + 1;
        END IF;
        FETCH cur_record INTO t_uuid;
        END WHILE;
    
        COMMIT;
        CLOSE cur_record;
        # 游标释放
    END;
    
    
    展开全文
  • mysql存储过程 删除数据库所有表的存储过程
  • 我现在有两张表A,B,两张表有外键关联,现在我想使用mysql存储结构删除A表(关联B表)的数据,怎么写啊
  • mysql 存储过程详解

    万次阅读 多人点赞 2022-07-23 21:13:30
    mysql 存储过程详解

    前言

    在项目开发中,经常会遇到这样一种场景,当修改A表的一条数据时,需要关联修改B表、C表甚至其他更多表的数据,为什么会这样呢?

    在真实的业务场景中,往往一张表的数据关联的业务是多样的,举例来说,用户在页面上完成一个订单,对服务端来说,与这个订单相关的业务还有很多,比如生成一条出库记录,扣减库存,用户的账户余额扣减,商家的账户余额增加,财务结算等等…

    所有这些不同的业务员操作,在服务端来说,最终体现的就是与数据库的交互,可想而知,假如关联的业务越复杂,需要与数据库进行IO的次数就越多;

    那么有没有什么办法,在面对此类场景业务时,提升服务端的性能,减少数据库IO呢?这就是本篇将要分享的存储过程。

    什么是存储过程

    存储过程就是事先经过编译并存储在数据库中的一段 SQL 语句的集合;

    为什么使用存储过程

    调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。

    存储过程特点:

    • 封装,复用, 可以把某一业务SQL封装在存储过程中,需要用到的时候直接调用即可;
    • 可以接收参数,也可以返回数据, 在存储过程中,可以传递参数,也可以接收返回值;
    • 减少网络交互,提升效率,如果一次操作涉及到多条SQL,每执行一次都是一次网络传
      输。 如果将这些sql操作封装在存储过程中,只需网络交互一次可能就可以了;

    存储过程基础语法

    1、创建存储过程语法

    CREATE PROCEDURE 存储过程名称 ([ 参数列表 ])
    
    BEGIN
    
    -- SQL语句
    
    END ;
    

    一个简单的案例

    CREATE PROCEDURE p1()
    
    BEGIN
    	SELECT count(*) FROM account;
    END;
    

    2、调用存储过程

    CALL 名称 ([ 参数 ]);
    

    调用上面的存储过程

    call p1();
    

    在这里插入图片描述

    3、查看存储过程

    SHOW CREATE PROCEDURE 存储过程名称 ; -- 查询某个存储过程的定义
    

    在这里插入图片描述

    4、删除存储过程

    DROP PROCEDURE [ IF EXISTS ] 存储过程名称 ;
    

    在这里插入图片描述

    注意点:上面创建存储过程的语句在navicat或者sqlyog中没问题,但是放到命令行中执行会报错,在命令行中模式下,需要通过关键字 delimiter 指定SQL语句的结束符

    存储过程中的变量

    在MySQL中,变量一般可分为分为三种类型: 系统变量、用户定义变量、局部变量;

    一、系统变量

    系统变量是MySQL服务器系统自身提供的,分为全局变量(GLOBAL)、会话
    变量(SESSION);

    1)查看系统变量

    SHOW [ SESSION | GLOBAL ] VARIABLES ; -- 查看所有系统变量
    
    SHOW [ SESSION | GLOBAL ] VARIABLES LIKE '......'; -- 可以通过LIKE模糊匹配方 式查找变量
    
    SELECT @@[SESSION | GLOBAL] 系统变量名; -- 查看指定变量的值
    

    2)设置系统变量

    SET [ SESSION | GLOBAL ] 系统变量名 =;
    
    SET @@[SESSION | GLOBAL]系统变量名 =;
    

    如果没有指定SESSION/GLOBAL,默认是SESSION,会话变量。

    注意点:

    • mysql服务重新启动之后,所设置的全局参数会失效,要想不失效,可以在 /etc/my.cnf 中配置;
    • 全局变量(GLOBAL): 全局变量针对于所有的会话;
    • 会话变量(SESSION): 会话变量针对于单个会话,在另外一个会话窗口就不生效了;

    比如使用下面的语句查看系统的query_cache值

    SHOW VARIABLES LIKE '%query_cache%';
    

    二、用户自定义变量

    用户定义变量,是用户根据需要自己定义的变量,用户自定义变量不用提前声明,在用的时候直接用 “@变量名” 使用就可以。其作用域为当前session的连接。

    1、使用如下方式自定义变量

    SET @var_name = expr [, @var_name = expr] ... ;
    
    SET @var_name := expr [, @var_name := expr] ... ;
    

    赋值时,可以使用 = ,也可以使用 := 。

    在这里插入图片描述

    2、使用select into 的方式给变量赋值

    SELECT @var_name := expr [, @var_name := expr] ... ;
    
    SELECT 字段名 INTO @var_name FROM 表名;
    

    在这里插入图片描述

    注意: 用户定义变量无需对其进行声明或初始化,只不过获取到的值为NULL而已;

    三、局部变量

    1、局部变量定义

    根据需要定义的在局部生效的变量,访问前,需通过DECLARE声明。可用作存储过程内的局部变量和输入参数,局部变量的范围是在其内声明的BEGIN … END块。

    2、定义方式

    DECLARE 变量名 变量类型 [DEFAULT ... ] ;
    

    变量类型就是数据库字段类型,可选值包括:INT、BIGINT、CHAR、VARCHAR、DATE、TIME等。

    一个简单的案例

    
    create procedure p2()
    
    BEGIN
    
    			declare my_count int default 0;
    			select count(*) into my_count from account;
    			select my_count;
    
    END;
    

    执行下调用

    在这里插入图片描述

    四、条件判断语句if的使用

    条件判断可以说在很多编程语言中都不陌生,在存储过程中也一样,而且使用的场景很多,务必掌握;

    1、if 条件语句语法结构

    IF 条件1 THEN
    	.....
    ELSEIF 条件2 THEN -- 可选
    	.....
    ELSE -- 可选
    	.....
    END IF;
    

    在if条件判断结构中,ELSE IF 结构可以有多个,也可以没有。 ELSE结构可以有,也可以没有。

    一个简单的案例,判断分数在不同的区间,然后输出不同的值;

    create procedure p3()
    
    BEGIN
    
    	declare score int default 59;
    	declare result VARCHAR(12);
    	if score >= 85 then
    		set result := '优秀';
    	elseif score >= 60 then
    		set result := '及格';
    	else
    		set result := '不及格';
    
    	end if;
    
    	select result;
    
    END;
    

    执行下调用

    在这里插入图片描述

    2、case - when 语法

    在实际编码中,与if-else 相似作用的还有case-when 这种写法,也是比较常用的写法;

    CASE case_value
    	WHEN when_value1 THEN statement_list1
    	
    	[ WHEN when_value2 THEN statement_list2] ...
    	
    	[ ELSE statement_list ]
    	
    END CASE;
    

    解释说明

    • 当case_value的值为 when_value1时,执行statement_list1;
    • 当值为 when_value2时, 执行statement_list2, 否则就执行 statement_list;

    还有另一种语法结构如下:

    CASE
    
    	WHEN search_condition1 THEN statement_list1
    	
    	[WHEN search_condition2 THEN statement_list2] ...
    	
    	[ELSE statement_list]
    	
    END CASE;
    

    解释说明:

    • 当条件search_condition1成立时,执行statement_list1
    • 当条件search_condition2成 立时,执行statement_list2, 否则就执行 statement_list;

    如果用case-when对上面的进行改造如下:

    create procedure p5()
    
    BEGIN
    
    	declare score int default 77;
    	declare result VARCHAR(12);
    
    	case
    		when score >= 85 then
    				set result := '优秀';
    
    		when score >= 60 then
    				set result := '及格';
    		
    		else
    				set result := '未知结果';
    
    	end case;	
    
    	select result;
    
    END;
    

    执行调用

    在这里插入图片描述

    上面的这种写法存在什么问题呢?很明显,不够灵活,通常来说,在实际业务中,我们更希望存储过程能够接收参数,并且返回处理结果,以便提供给后续的业务逻辑使用,这就需要用到存储过程的输入输出参数了;

    五、存储过程输入输出参数使用

    存储过程中使用到的参数的类型,主要分为以下三种:IN、OUT、INOUT;

    类型含义备注说明
    IN该类参数作为输入,也就是需要调用时传入值默认
    OUT该类参数作为输出,也就是该参数可以作为返回值
    INOUT既可以作为输入参数,也可以作为输出参数

    1、语法定义

    CREATE PROCEDURE 存储过程名称 ([ IN/OUT/INOUT 参数名 参数类型 ])
    
    BEGIN
    	-- SQL
    END;
    

    将上面的案例进行简单改造,通过外面传入的参数,判断分数在不同的区间,从而返回不同的结果;

    create procedure p4(in score int,out result varchar(12))
    
    BEGIN
    
    	if score >= 85 then
    		set result := '优秀';
    	elseif score >= 60 then
    		set result := '及格';
    	else
    		set result := '不及格';
    
    	end if;
    
    END;
    

    执行下调用

    call p4(90,@result);
    
    select @result;
    

    在这里插入图片描述

    案例演示

    下面有一张员工表

    在这里插入图片描述

    案例需求:

    创建存储过程show_emp_salary(),查看 employees 表的某个员工的薪资,并用IN参数emp_name 输入员工姓名,并返回薪资;

    CREATE PROCEDURE show_emp_salary (IN emp_name VARCHAR(20),OUT emp_salary INT) 
    
    BEGIN
    		select salary into emp_salary from employees WHERE first_name = emp_name;
    
    END ;
    

    执行调用

    在这里插入图片描述

    六、存储过程中的循环使用

    循环语句在编程中经常被用到,常用于对批量的数据进行循环处理,在mysql的存储过程中,也提供了几种常用的循环语句,包括:while循环,repeat循环,和loop循环;

    1、while循环语句

    while 循环是有条件的循环控制语句。满足条件时,再执行循环体中的SQL语句;

    WHILE 条件 DO
    
    	SQL逻辑...
    	
    END WHILE;
    

    先判定条件,如果条件为true,则执行逻辑,否则,不执行逻辑

    需求:从1累加到N,并求出累加的结果

    create procedure p6(in n int)
    
    	begin
    
    		declare total int default 0;
    
    		while n>0 do
    			set total := total + n;
    			set n := n - 1 ;
    
    		end while;
    
    		select total;
    
    	end ;
    

    执行下调用

    在这里插入图片描述

    2、repeat 循环语句

    repeat是有条件的循环控制语句, 当满足 until 声明的条件的时候,则退出循环,语法结构为:

    REPEAT
    
    	SQL逻辑...
    	UNTIL 条件
    	END REPEAT;
    

    先执行一次逻辑,然后判定UNTIL条件是否满足,如果满足,则退出。如果不满足,则继续下一次循环;

    仍然使用上面的累计求和的需求进行改造如下:

    create procedure p7(in n int)
    
    	begin
    
    		declare total int default 0;
    
    		repeat 
    			set total := total + n;
    			set n := n - 1;
    
    		until n <= 0
    			
    		end repeat;
    
    		select total;
    
    	end ;
    

    执行调用

    在这里插入图片描述

    3、loop 循环语句

    LOOP 可以实现简单的循环,如果不在SQL逻辑中增加退出循环的条件,可以用其来实现简单的死循环。LOOP可以配合一下两个语句使用:

    • LEAVE :配合循环使用,退出循环;
    • ITERATE:必须用在循环中,作用是跳过当前循环剩下的语句,直接进入下一次循环;

    语法结构如下:

    [begin_label:] LOOP
    
    	SQL逻辑...
    	
    END LOOP [end_label];
    

    说明:

    • LEAVE label; – 退出指定标记的循环体
    • ITERATE label; – 直接进入下一次循环

    上述语法中的 begin_label,end_label,label 指的是我们自定义的标记名称;

    使用loop语法完成上面的从1到N的累加求和

    create procedure p8(in n int)
    
    	begin
    
    		declare total int default 0;
    
    		
    		sum:loop
    			if n<=0 then 
    					leave sum;
    
    			end if;
    
    			set total := total + n;
    			set n := n - 1;
    
    		
    		end loop sum;
    
    		select total;
    
    	end ;
    

    执行调用

    在这里插入图片描述

    七、存储函数

    存储函数是有返回值的存储过程,存储函数的参数只能是IN类型的,语法定义如下:

    CREATE FUNCTION 存储函数名称 ([ 参数列表 ])
    
    RETURNS type [characteristic ...]
    
    	BEGIN
    		-- SQL语句
    		RETURN ...;
    	END ;	
    

    characteristic说明:

    • DETERMINISTIC:相同的输入参数总是产生相同的结果;
    • NO SQL :不包含 SQL 语句;
    • READS SQL DATA:包含读取数据的语句,但不包含写入数据的语句;

    存储函数案例1:求1到N的累加

    create function fun_add(n int)
    
    returns int deterministic
    
    BEGIN
    
    		declare sum int default 0;
    		while n > 0 do
    				set sum := sum + n;
    				set n := n - 1;
    		end while;
    
    		return sum;
    END;
    

    执行调用

    在这里插入图片描述

    通常来说,存储函数能够完成的事情,使用存储过程也可以完成,但是存储函数的局限在于,函数必须要有返回结果;

    八、存储过程中游标的使用

    游标(CURSOR)是用来存储查询结果集的数据类型 , 在存储过程和函数中可以使用游标对结果集进行循环的处理;

    游标,提供了一种灵活的操作方式,让我们能够对结果集中的每一条记录进行定位,并对指向的记录中的数据进行操作的数据结构。游标让 SQL 这种面向集合的语言有了面向过
    程开发的能力;

    在 SQL 中,游标是一种临时的数据库对象,可以指向存储在数据库表中的数据行指针。这里游标 充当了 指针的作用 ,我们可以通过操作游标来对数据行进行操作。

    游标的使用包括游标的声明、OPEN、FETCH 和 CLOSE,其语法分别如下:

    1、声明游标

    DECLARE 游标名称 CURSOR FOR 查询语句 ;
    

    2、 打开游标

    OPEN 游标名称 ;
    

    3、获取游标记录

    FETCH 游标名称 INTO 变量 [, 变量 ] ;
    

    4、关闭游标

    CLOSE 游标名称 ;
    

    案例需求,有下面一张员工表,创建一个存储过程,声明IN参数 limit_total_salary,DOUBLE类型;声明OUT参数total_count,INT类型。函数的功能可以实现累加薪资最高的几个员工的薪资值,直到薪资总和达到limit_total_salary参数的值,返回累加的人数给total_count;

    CREATE PROCEDURE get_count_by_limit_total_salary(IN limit_total_salary DOUBLE,OUT total_count INT)
    
    BEGIN
    	DECLARE sum_salary DOUBLE DEFAULT 0; #记录累加的总工资
    	DECLARE cursor_salary DOUBLE DEFAULT 0; #记录某一个工资值
    	DECLARE emp_count INT DEFAULT 0; #记录循环个数
    
    	#定义游标 
    	DECLARE emp_cursor CURSOR FOR SELECT salary FROM employees ORDER BY salary DESC;
    
    	#打开游标 
    	OPEN emp_cursor;
    
    	REPEAT
    
    		#使用游标(从游标中获取数据)
    		FETCH emp_cursor INTO cursor_salary;
    
    		SET sum_salary = sum_salary + cursor_salary;
    		SET emp_count = emp_count + 1;
    
    		UNTIL sum_salary >= limit_total_salary
    
    	END REPEAT;
    
    	SET total_count = emp_count;
    	
    	#关闭游标
    
    	CLOSE emp_cursor;
    
    END ;
    

    执行下调用

    在这里插入图片描述

    通过上面的案例,我们体验了一下游标的强大之处,事实上,在很多时候,我们希望通过游标将获取到的记录输出到一个中间记录表中,以供后续的业务处理,利用游标来做就非常合适,看下面的需求:

    根据传入的参数salary,来查询用户表employees中,所有工资大于等于15000的员工ID,以及first_name,并将员工的ID和first_name插入到一张新表;

    create procedure p_emp(in in_salary int)
    
    begin
    
    	declare u_empid int(12);
    	declare u_fname varchar(100);
    	declare u_cursor cursor for select employee_id,first_name from employees where salary >= in_salary;
    
    	-- 声明条件处理程序 : 当SQL语句执行抛出的状态码为02000时,将关闭游标u_cursor,并退出
    	declare exit handler for SQLSTATE '02000' close u_cursor;
    
    	drop table if exists tb_em_pro;
    
    	create table if not exists tb_em_pro( 
    			id int primary key auto_increment, 
    			employee_id int(12), 
    			first_name varchar(20) 
    	);
    
    	-- 打开游标
    	open u_cursor;
    	
    	while true do
    			fetch u_cursor into u_empid,u_fname;
    			insert into tb_em_pro values (null, u_empid, u_fname);
    	end while;
    
    	-- 关闭游标
    	close u_cursor;
    
    end;
    

    执行下调用

    在这里插入图片描述
    在这里插入图片描述

    执行完毕后,可以看到通过游标处理完毕的数据写到一张中间表中去了

    展开全文
  • MySQL利用存储过程批量插入数据

    千次阅读 2021-08-19 09:23:48
    因最近想要测试一下MySQL百万级数据处理过程,所以要一次对数据库插入大量数据。 具体存储过程如下: delimiter $$$ create procedure inserttest() begin declare i int default 0; set i=0; start transaction; ...

    引言:

    因最近想要测试一下MySQL百万级数据处理过程,所以要一次对数据库插入大量数据。

    具体存储过程如下:

    delimiter $$$
    create procedure inserttest()
    begin
    declare i int default 0;
    set i=0;
    start transaction;
    while i<1000000 do
    INSERT INTO TEST (GID, NAME, AGE, ADDR, CREATEDATE, CLASS) VALUES (MD5(UUID()), '张三', '22', '河南省信阳市淮滨县谷堆乡栗园村', '2021-08-19', '幼儿园大班');
    set i=i+1;
    end while;
    commit;
    end
    $$$
    delimiter;
    call inserttest();
    

    在此存储过程中,我插入了一百万行数据,具体的插入语句可以自行修改。
    如果写完存储过程发现不是自己想要的,可以删除这个过程然后重写。删除存储过程的SQL语句如下:

    DROP PROCEDURE IF EXISTS inserttest;
    
    展开全文
  • mysql存储过程教程(1)

    千次阅读 2021-02-07 17:30:12
    MySQL存储过程1.1 CREATE PROCEDURE (创建)CREATE PROCEDURE存储过程名(参数列表)BEGINSQL语句代码块END注意:由括号包围的参数列必须总是存在。如果没有参数,也该使用一个空参数列()。每个参数默认都是一个IN参数...
  • #如果存在则删除存储过程 DROP PROCEDURE IF EXISTS usp_generate_order_data; #指定分隔符为// DELIMITER // #创建存储过程 CREATE PROCEDURE usp_generate_order_data() BEGIN #如果存在则删除该临时表 DROP ...
  • mysql 存储过程

    千次阅读 2021-01-18 21:29:44
    为什么要用存储过程将重复性很高的操作,封装到一个存储过程中,简化了对这些SQL的调用批量处理统一接口,确保数据安全相对于Oracle来说,Mysql存储过程相对功能较弱,使用较少​3.存储过程的创建和调用1. ...
  • MySQL存储过程如何操作

    千次阅读 2021-03-04 00:08:16
    mysql在5.1之后增加了存储过程的功能, 存储过程运行在mysql内部,语句都已经编译好了,速度比sql更快.... 看了如下存储过程实例,你会发现mysql存储过程和shell很像.下面存储过程内容为:调用存储过...
  • 存储过程 1 什么是存储过程 1.存储过程,带有逻辑的sql语句 2.之前的sql没有条件判断,没有循环 3.存储过程带上流程控制语句(if while) 2 存储过程特点 1)执行效率非常快!存储过程是在数据库的服务器端...
  • mysql 通过存储过程批量更新表数据

    千次阅读 2021-01-21 04:48:20
    方法一:使用临时表批量更新表数据 (注意操作用户需要有mysql的创建临时表权限)delimiter $$# 删除 已有的 存储过程DROP PROCEDURE IF EXISTS update_user_account_method;# 创建新的存储过程CREATE PROCEDURE ...
  • 一、什么是存储过程二、存储过程怎么创建三、查看四、执行1、执行说明2、开始执行五、删除存储过程六、Mysql高版本:this is incompatible with sql_mode=only_full_group_by 问题 一、什么是存储过程 存储过程是一...
  • 2:使用MySQL存储过程 若使用第一种办法的话,需要重新发布版本,比较麻烦,再加上领导对发布版本有些抵触,我觉得我们还是使用第二种方式比较快捷。 1. 表结构 测试表结构如下: CREATE TABLE `member_album` ( ...
  • MySQL存储过程使用游标循环数据列表

    千次阅读 2019-02-26 10:04:43
    本篇文章主要讲解,我的一个案例,使用存储...MySQL使用存储过程循环数据列表? 2、先描述下MySQL有哪些循环的语法 while循环 CREATE PROCEDURE proc_while () BEGIN DECLARE num INT ; SET num = 0 ; ...
  • mysql存储过程创建

    千次阅读 2022-04-09 17:31:00
    mysql存储过程、mysql批量创建数据,创建10+数据
  • MySql存储过程和游标的使用。

    千次阅读 2022-03-24 09:30:07
    这里存储过程和游标的定义和作用就不介绍了,网上挺多的,只通过简单的介绍,然后用个案例让大家快速了解。实例中会具体说明变量的定义,赋值,游标的使用,控制语句,循环...MySQL存储过程的参数用在存储过程的定义
  • Mysql函数和存储过程

    千次阅读 2022-06-15 09:14:08
    设置变量 定义用户变量 : set @...IN 类型参数可以接收变量也可以接收常量,传入的参数在存储过程内部使用即可,但是在存储过程内部的修改无法传递到外部。OUT 类型参数只能接收一个变量,接收的变量不能够在存储
  • mysql存储过程学习笔记

    万次阅读 多人点赞 2019-02-22 17:09:36
    本文主要记录了本人学习mysql存储过程时的笔记,文档中用到的表结构在文档结尾处有说明。 一、定义  存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,...
  • 之前写过oracle和mysql的递归查询和删除,这次再补上一个mysql的递归实现。 1、实现原理 (1)删除临时表 (2)创建临时表并清空 (3)利用临时表用来存放递归遍历出来的id列表 (4)从临时表中查询id列表 2、...
  • MySQL中的存储过程(详细篇)

    万次阅读 多人点赞 2022-04-14 20:20:36
    MySQL5.0 版本开始支持存储过程。 如果在实现用户的某些需求时,需要编写一组复杂的SQL语句才能实现的时候,那么我们就可以将这组复杂的SQL语句集提前编写在数据库中,由JDBC调用来执行这组SQL语句。把编写在...
  • mysql 存储过程 create or replace

    千次阅读 2021-01-19 04:13:16
    MySQL和Oracle对比之存储过程昨天晚上帮一个朋友处理了一个关于存储过程的问题,他需要迁移一些Oracle中的存储过程MySQL中来,但是改了一部分的程序,发现MySQL中没法编译了,报了很多的错误。这个问题也比较典型...
  • 在执行压测脚本之前,我们通常要准备数据库存量数据,一般是以生产数据为依据成比例增加,少则需要上百万,多则需要上千万、上亿,经常有很多时间要花在造数据上。   目前常用的造数据方法有: 1、通过编程语言...
  • MySQL存储过程的简单使用案例

    千次阅读 2022-03-25 15:13:39
    结合mysql+springboot简单调用存储过程
  • MySQL-存储过程(数据类型、函数)

    千次阅读 2019-05-25 03:33:45
    主要介绍存储过程的创建,注意事项,数据类型,常用函数。
  • 而且,存储过程和函数是在MySQL服务器中存储和执行的,可以减少客户器端和服务端的数据传输。 创建存储过程 创建存储过程和函数是指将经常使用的一组SQL语句组合在一起,并将这些SQL语句当作一个整体存储在...
  • MySQL存储过程及日期时间函数的用法

    千次阅读 2020-10-16 15:43:32
    二、存储过程2.1存储过程的优点2.2创建存储过程2.3 in表示传入参数 前言 一、日期时间函数 MySQL 也支持日期时间处理,提供了很多处理日期和时间的函数。一些常用的日期时间函数 字符串函数 描述 curdate() 返回...
  • MySQL修改、删除存储过程和函数

    千次阅读 2019-09-02 16:49:04
    使用alter语句可以修改存储过程或函数的特性。 alter {procedure | function } sp_name {characteristic ...} 其中,sp_name参数表示存储过程或函数的名称,characteristic参数指定存储函数的特性,可能取的取值有...
  • MySQL---存储过程详解

    万次阅读 多人点赞 2021-03-16 11:03:41
    MySQL5.0 版本开始支持存储过程。 大多数 SQL 语句都是针对一个或多个表的单条语句。并非所有的操作都那么简单。经常会有一个完整的操作需要多条语句才能完成。 存储过程简单来说,就是为以后的使用而保存的一条或多...
  • 如何在MySQL中使用存储过程

    千次阅读 2022-03-27 15:29:04
    MySQL存储过程及MySQL循环语句的基本使用

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 363,016
精华内容 145,206
关键字:

mysql存储过程删除数据

mysql 订阅