sql中的if和else使用及說明
sql中的if和else
MySQL的IF既可以作為表達(dá)式用,也可在存儲(chǔ)過程中作為流程控制語(yǔ)句使用,如下是做為表達(dá)式使用:
IF表達(dá)式
IF(expr1,expr2,expr3)
如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),則 IF()的返回值為expr2; 否則返回值則為 expr3。IF() 的返回值為數(shù)字值或字符串值,具體情況視其所在語(yǔ)境而定。
SELECT IF(sva=1,"男","女") AS s FROM table_name? WHERE sva != '';
作為表達(dá)式的if也可以用CASE WHEN來實(shí)現(xiàn):
SELECT CASE sva WHEN 1 THEN '男'? ELSE '女'? END AS s? FROM table_name WHERE sva != '';
在第一個(gè)方案的返回結(jié)果中, value=compare-value。
而第二個(gè)方案的返回結(jié)果是第一種情況的真實(shí)結(jié)果。
如果沒有匹配的結(jié)果值,則返回結(jié)果為ELSE后的結(jié)果,如果沒有ELSE 部分,則返回值為 NULL。
例如:
SELECT CASE 1? WHEN 1 THEN 'one' WHEN 2 THEN 'two'? ? ?ELSE 'more'? END AS test 將輸出one
IFNULL(expr1,expr2)
假如expr1 不為 NULL,則 IFNULL() 的返回值為 expr1; 否則其返回值為 expr2。
IFNULL()的返回值是數(shù)字或是字符串,具體情況取決于其所使用的語(yǔ)境。
?SELECT IFNULL(1,0); ?-> 1 SELECT IFNULL(NULL,10); ?-> 10 SELECT IFNULL(1/0,10); -> 10 SELECT IFNULL(1/0,'yes'); -> 'yes'
IFNULL(expr1,expr2) 的默認(rèn)結(jié)果值為兩個(gè)表達(dá)式中更加“通用”的一個(gè),順序?yàn)镾TRING、 REAL或 INTEGER。
IF ELSE 做為流程控制語(yǔ)句使用
IF實(shí)現(xiàn)條件判斷,滿足不同條件執(zhí)行不同的操作,這個(gè)我們只要學(xué)編程的都知道IF的作用了,下面我們來看看mysql 存儲(chǔ)過程中的IF是如何使用的吧。
IF search_condition? THEN statement_list ? [ELSEIF search_condition THEN] ? ? ? statement_list ... ? [ELSE statement_list] ? END IF?
當(dāng)IF中條件search_condition成立時(shí),執(zhí)行THEN后的statement_list語(yǔ)句,否則判斷ELSEIF中的條件,成立則執(zhí)行其后的statement_list語(yǔ)句,否則繼續(xù)判斷其他分支。
當(dāng)所有分支的條件均不成立時(shí),執(zhí)行ELSE分支。search_condition是一個(gè)條件表達(dá)式,可以由“=、<、<=、>、>=、!=”等條件運(yùn)算符組成,并且可以使用AND、OR、NOT對(duì)多個(gè)表達(dá)式進(jìn)行組合。
例如,建立一個(gè)存儲(chǔ)過程,該存儲(chǔ)過程通過學(xué)生學(xué)號(hào)(student_no)和課程編號(hào)(course_no)查詢其成績(jī)(grade),返回成績(jī)和成績(jī)的等級(jí),成績(jī)大于90分的為A級(jí),小于90分大于等于80分的為B級(jí),小于80分大于等于70分的為C級(jí),依次到E級(jí)。
那么,創(chuàng)建存儲(chǔ)過程的代碼如下:
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
注意:IF作為一條語(yǔ)句,在END IF后需要加上分號(hào)“;”以表示語(yǔ)句結(jié)束,其他語(yǔ)句如CASE、LOOP等也是相同的。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MSSQL數(shù)據(jù)類型及長(zhǎng)度限制詳細(xì)說明
在 Microsoft® SQL Server™ 中,每個(gè)列、局部變量、表達(dá)式和參數(shù)都有一個(gè)相關(guān)的數(shù)據(jù)類型,這是指定對(duì)象可持有的數(shù)據(jù)類型(整型、字符、money 等等)的特性。2008-08-08SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000)
"無法打開新數(shù)據(jù)庫(kù) 'POS'。CREATE DATABASE 中止。 (Microsoft SQL Server,錯(cuò)誤: 9003)"看是9003錯(cuò)誤,怎么解決呢,下面小編給大家分享SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000),一起看看吧2016-09-09SQL語(yǔ)句過濾條件放在on與where子句中的區(qū)別和聯(lián)系淺析
在寫SQL語(yǔ)句的時(shí)候,我們經(jīng)常會(huì)用到各種表連接,還有各種分組聚合函數(shù),下面這篇文章主要給大家介紹了關(guān)于SQL語(yǔ)句過濾條件放在on與where子句中的區(qū)別和聯(lián)系,需要的朋友可以參考下2022-09-09去掉前面的0的sql語(yǔ)句(前導(dǎo)零,零前綴)
一個(gè)列的格式是單引號(hào)后面跟著4位的數(shù)字,比如’0003,’0120,’4333,我要轉(zhuǎn)換成3,120,4333這樣的格式,就是去掉單引號(hào)和前導(dǎo)的0,用以下語(yǔ)句就可以。2011-08-08SQL Server日志恢復(fù)還原數(shù)據(jù)的操作流程
有時(shí)開發(fā)過程中由于不小心或者程序出現(xiàn)錯(cuò)誤導(dǎo)致錯(cuò)誤刪除數(shù)據(jù),或者由于計(jì)算機(jī)以外引起數(shù)據(jù)遭到破壞,這時(shí)候可以采用日志進(jìn)行恢復(fù),所以本文給大家介紹了SQL Server日志恢復(fù)還原數(shù)據(jù)的操作流程,需要的朋友可以參考下2024-09-09SQL Server創(chuàng)建數(shù)據(jù)庫(kù)圖文教程
這篇文章主要介紹了SQL Server創(chuàng)建數(shù)據(jù)庫(kù)圖文教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02有關(guān)sqlserver帳號(hào)被禁用的處理方法
這篇文章主要介紹了有關(guān)sqlserver帳號(hào)被禁用處理方法,需要的朋友可以參考下2017-12-12