您当前的位置:首页 > 互联网教程

mysql存储过程的if判断有多个条件该怎么优化效率

发布时间:2025-05-12 15:00:40    发布人:远客网络

mysql存储过程的if判断有多个条件该怎么优化效率

一、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);