mysql中有如下的幾個的控制流程的語句:
1) case
實例
代碼如下 復制代碼CASE case_value
WHEN when_value THEN statement_list
[WHEN when_value THEN statement_list] ...
[ELSE statement_list]
END CASE
或者
CASE
WHEN search_condition THEN statement_list
[WHEN search_condition THEN statement_list] ...
[ELSE statement_list]
END CASE
2)if 語句
SELECT IF(expr1,expr2,expr3);
// return yes
SELECT IF(1<5,'yes','no');
有三個參數,如果第1個表達式返回true,則返回表達式2,否則返回表達式3
實例
create procedure dbname.proc_getGrade
(stu_no varchar(20),cour_no varchar(10))
BEGIN
declare stu_grade float;
select grade into stu_grade from grade where student_no=stu_no and course_no=cour_no;
if stu_grade>=90 then
select stu_grade,'A';
elseif stu_grade<90 and stu_grade>=80 then
select stu_grade,'B';
elseif stu_grade<80 and stu_grade>=70 then
select stu_grade,'C';
elseif stu_grade70 and stu_grade>=60 then
select stu_grade,'D';
else
select stu_grade,'E';
end if;
END
3) ifnull
如果expr1不是NULL,IFNULL()返回expr1,否則它返回expr2。IFNULL()返回一個數字或字符串值,取決於它被使用的上下文環境。
代碼如下 復制代碼 mysql> select IFNULL(1,0);
IF(expr1,expr2,expr3)
如果expr1是TRUE(expr1<>0且expr1<>NULL),那麼IF()返回expr2,否則它返回expr3。IF()返回一個數字或字符串值,取決於它被使用的上下文。
expr1作為整數值被計算,它意味著如果你正在測試浮點或字符串值,你應該使用一個比較操作來做。
在上面的第一種情況中,IF(0.1)返回0,因為0.1被變換到整數值, 導致測試IF(0)。這可能不是你期望的。在第二種情況中,比較測試原來的浮點值看它是否是非零,比較的結果被用作一個整數
4)nullif
5)存儲過程的
代碼如下 復制代碼mysql>create procedure ifprod()
->begin
->set @x=0;
->ins:loop;
->set @x=@x+1;
if @x=100 then
leave ins;
end if
insert into actor(firestname)values('www.111cn.net');
end loop ins;
end;
->$$
Query Ok, 0 rows affected (0.00 sec);