欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql存儲(chǔ)過(guò)程之if語(yǔ)句用法實(shí)例詳解

 更新時(shí)間:2019年12月26日 11:13:57   作者:luyaran  
這篇文章主要介紹了mysql存儲(chǔ)過(guò)程之if語(yǔ)句用法,結(jié)合實(shí)例形式詳細(xì)分析了mysql存儲(chǔ)過(guò)程中if語(yǔ)句相關(guān)原理、使用技巧與操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了mysql存儲(chǔ)過(guò)程之if語(yǔ)句用法。分享給大家供大家參考,具體如下:

mysql中的 IF語(yǔ)句允許我們根據(jù)表達(dá)式的某個(gè)條件或值結(jié)果來(lái)執(zhí)行一組SQL語(yǔ)句,所以我們要在MySQL中形成一個(gè)表達(dá)式,可以結(jié)合文字,變量,運(yùn)算符,甚至函數(shù)來(lái)組合。表達(dá)式可以返回TRUE,FALSE或NULL,這三個(gè)值之一。來(lái)看下語(yǔ)法結(jié)構(gòu):

IF expression THEN
  statements;
END IF;

如果上述表達(dá)式(expression)計(jì)算結(jié)果為T(mén)RUE,那么將執(zhí)行statements語(yǔ)句,否則控制流將傳遞到END IF之后的下一個(gè)語(yǔ)句。咱們來(lái)看下IF語(yǔ)句的執(zhí)行過(guò)程:

咱們?cè)賮?lái)看下IF ELSE語(yǔ)句的語(yǔ)法結(jié)構(gòu):

IF expression THEN
  statements;
ELSE
  else-statements;
END IF;

完事就來(lái)看IF ELSE語(yǔ)句的執(zhí)行過(guò)程:

我們?nèi)绻诙鄠€(gè)表達(dá)式有條件地執(zhí)行語(yǔ)句,則使用IF ELSEIF ELSE語(yǔ)句,它的語(yǔ)法結(jié)構(gòu)如下:

IF expression THEN
  statements;
ELSEIF elseif-expression THEN
  elseif-statements;
...
ELSE
  else-statements;
END IF;

如果表達(dá)式(expression)求值為T(mén)RUE,則IF分支中的語(yǔ)句(statements)將執(zhí)行;如果表達(dá)式求值為FALSE,并且elseif_expression的計(jì)算結(jié)果為T(mén)RUE,mysql將執(zhí)行elseif-expression,否則執(zhí)行ELSE分支中的else-statements語(yǔ)句。咱們來(lái)看下具體的執(zhí)行過(guò)程:

咱們接下來(lái)使用IF ESLEIF ELSE語(yǔ)句和GetCustomerLevel()存儲(chǔ)過(guò)程接受客戶(hù)編號(hào)和客戶(hù)級(jí)別的兩個(gè)參數(shù)。首先這個(gè)GetCustomerLevel()存儲(chǔ)過(guò)程得先從customers表中獲得信用額度,完事呢,根據(jù)信用額度,它決定客戶(hù)級(jí)別:PLATINUM , GOLD 和 SILVER 。參數(shù)p_customerlevel存儲(chǔ)客戶(hù)的級(jí)別,并由調(diào)用程序使用,咱們來(lái)看下具體的sql:

DELIMITER $$
CREATE PROCEDURE GetCustomerLevel(
  in p_customerNumber int(11),
  out p_customerLevel varchar(10))
BEGIN
  DECLARE creditlim double;
  SELECT creditlimit INTO creditlim
  FROM customers
  WHERE customerNumber = p_customerNumber;
  IF creditlim > 50000 THEN
 SET p_customerLevel = 'PLATINUM';
  ELSEIF (creditlim <= 50000 AND creditlim >= 10000) THEN
    SET p_customerLevel = 'GOLD';
  ELSEIF creditlim < 10000 THEN
    SET p_customerLevel = 'SILVER';
  END IF;
END$$

確定客戶(hù)級(jí)別的邏輯的流程圖如下:

好啦,本次分享就到這里了。

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《MySQL存儲(chǔ)過(guò)程技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》及《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總

希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論