真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL中有哪些流程函數(shù)

這篇文章將為大家詳細(xì)講解有關(guān)MySQL中有哪些流程函數(shù),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

創(chuàng)新互聯(lián)建站專注于藍(lán)山企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),電子商務(wù)商城網(wǎng)站建設(shè)。藍(lán)山網(wǎng)站建設(shè)公司,為藍(lán)山等地區(qū)提供建站服務(wù)。全流程按需定制開發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)

流程函數(shù)是MySQL相對(duì)常用的一類函數(shù), 用戶可以使用這類函數(shù)在一個(gè)SQL語句中實(shí)現(xiàn)條件選擇, 這樣能夠提高效率.

下面列出了MySQL跟條件有關(guān)的流程函數(shù)

函數(shù)功能
IF(expr1,expr2,expr3)如果expr1是真, 返回expr2, 否則返回expr3
IFNULL(expr1,expr2)如果expr1不是NULL,返回expr1,否則返回expr2
CASE WHEN [value1] THEN[result1]… ELSE[default] END如果value是真, 返回result1,否則返回default
CASE [expr] WHEN [value1] THEN[result1]… ELSE[default] END如果expr等于value1, 返回result1,否則返回default

下面的例子中模擬對(duì)職員進(jìn)行分類,首先創(chuàng)建一個(gè)職員薪水表:

create table salary(userid int, salary decimal(9,2));

插入一些測(cè)試數(shù)據(jù)

insert into salary values (1,1000),(2,2000),(3,3000),(4,4000),(5,5000),(1,null);

數(shù)據(jù)如下

mysql> select * from salary;
+--------+---------+
| userid | salary |
+--------+---------+
| 1 | 1000.00 |
| 2 | 2000.00 |
| 3 | 3000.00 |
| 4 | 4000.00 |
| 5 | 5000.00 |
| 1 | NULL |
+--------+---------+
6 rows in set (0.00 sec)

接下來, 通過這個(gè)表來介紹各個(gè)函數(shù)的應(yīng)用.

IF(expr1,expr2,expr3)函數(shù): 這里認(rèn)為月薪在2000元以上的職員屬于高薪, 用"high'表示; 而2000以下的職員屬于低薪, 用'low'來表示.

mysql> select if(salary>2000, 'high', 'low') from salary;    
+--------------------------------+
| if(salary>2000, 'high', 'low') |
+--------------------------------+
| low              |
| low              |
| high              |
| high              |
| high              |
| low              |
+--------------------------------+
6 rows in set (0.00 sec)

IFNULL(expr1,expr2)函數(shù): 這個(gè)函數(shù)一般用來替換NULL值, 我們知道NULL值是不能參參與數(shù)值運(yùn)算的, 下面這個(gè)語句就是把NULL值用0替換.

mysql> select ifnull(salary,0) from salary;
+------------------+
| ifnull(salary,0) |
+------------------+
|     1000.00 |
|     2000.00 |
|     3000.00 |
|     4000.00 |
|     5000.00 |
|       0.00 |
+------------------+
6 rows in set (0.00 sec)

CASE WHEN [value1] THEN[result1]… ELSE[default] END函數(shù):這里可以用case when..then函數(shù)實(shí)現(xiàn)上面例子中高薪低薪的問題.

mysql> select CASE WHEN salary<=2000 THEN 'low' else 'high' END from salary;
+---------------------------------------------------+
| CASE WHEN salary<=2000 THEN 'low' else 'high' END |
+---------------------------------------------------+
| low                        |
| low                        |
| high                       |
| high                       |
| high                       |
| high                       |
+---------------------------------------------------+
6 rows in set (0.00 sec)

CASE [expr] WHEN [value1] THEN[result1]… ELSE[default] END函數(shù):這里還可以分為多種情況把職員的薪水分為多個(gè)檔次,比如下面的例子分成高、中、低3種情況。同樣可以分成更多種情況,這里不再舉例了,有興趣的朋友可以自己測(cè)試一下

mysql> select CASE salary WHEN 1000 THEN 'low' when 2000 THEN 'mid' ELSE 'high' END from salary;
+-----------------------------------------------------------------------+
| CASE salary WHEN 1000 THEN 'low' when 2000 THEN 'mid' ELSE 'high' END |
+-----------------------------------------------------------------------+
| low                                  |
| mid                                  |
| high                                 |
| high                                 |
| high                                 |
| high                                 |
+-----------------------------------------------------------------------+
6 rows in set (0.00 sec)

關(guān)于MySQL中有哪些流程函數(shù)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。


新聞名稱:MySQL中有哪些流程函數(shù)
URL標(biāo)題:http://weahome.cn/article/giggds.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部