mysql存储过程的if判断有多个条件该怎么优化效率
发布时间:2025-05-12 15:00:40 发布人:远客网络
一、mysql存储过程的if判断有多个条件该怎么优化效率
1、这个应该不会太慢吧,我建议你看一下,你是不是循环做了太多次的插入/更新操作。
2、mysql默认的配置中,每次事务提交都要写binlog和redo log,如果循环太多次——比如循环插入10w条记录——就会非常慢。一般优化思路分两种:
3、1修改 sync_binlog为一个100-1000间的值,让binlog每隔100-1000个事务后再写一次;修改innodb_flush_log_at_trx_commit=2;这么搞的好处是降低了写log的次数和消耗的时间,缺点是,中间出错的话,会丢失一部分的binlog和redolog导致无法通过他们来在出问题是恢复生产库数据。
4、2将所有的插入/更新操作放到一个事务中进行。这样,显然就只需要一次写binlong和redolog咯。
二、mysql 存储过程总结(二)if语句、参数
1、if:用于做条件判断,具体的语法结构为:
在if条件判断的结构中,ELSE IF结构可以有多个,也可以没有。 ELSE结构可以有,也可以没有。
根据定义的分数score变量,判定当前分数对应的分数等级。
score>= 90分,等级为优秀。
score< 60分,等级为不及格。
上述的需求我们虽然已经实现了,但是也存在一些问题,比如:score分数我们是在存储过程中定义死的,而且最终计算出来的分数等级,我们也仅仅是最终查询展示出来而已。
那么我们能不能,把score分数动态的传递进来,计算出来的分数等级是否可以作为返回值返回呢?答案是肯定的,我们可以通过接下来所讲解的参数来解决上述的问题。
主要分为以下三种:IN、OUT、INOUT。具体的含义如下:
(1)in:该类参数作为输入,也就是需要调用时传入值默认
(2)out:该类参数作为输出,也就是该参数可以作为返回值
(3)inout:既可以作为输入参数,也可以作为输出参数
三、SQL 中存储过程怎么使用
drop procedure if exists GetUsers;
1、MySql支持 IN(传递给存储过程), OUT(从存储过程传出)和 INOUT(对存储过程传入和传出)类型的参数,存储过程的代码位于 BEGIN和 END语句内,它们是一系列 SQL语句,用来检索值,然后保存到相应的变量(通过指定INTO关键字);
2、下面的存储过程接受三个参数,分别用于获取用户表的最小,平均,最大分数,每个参数必须具有指定的类型,这里使用十进制值(decimal(8,2)),关键字 OUT指出相应的参数用来从存储过程传出
select min(score) into minScore from user;
select avg(score) into avgScore from user;
select max(score) into maxScore from user;
3、调用此存储过程,必须指定3个变量名(所有 MySql变量都必须以@开始),如下所示:
call GetScores(@minScore,@avgScore,@maxScore);12
4、该调用并没有任何输出,只是把调用的结果赋给了调用时传入的变量@minScore,@avgScore,@maxScore,然后即可调用显示该变量的值:
select@minScore,@avgScore,@maxScore;
5、使用 IN参数,输入一个用户 id,返回该用户的名字:
call GetNameByID(1,@userName);