溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql中case when的作用是什么

發(fā)布時(shí)間:2020-09-04 14:22:25 來(lái)源:億速云 閱讀:568 作者:小新 欄目:MySQL數(shù)據(jù)庫(kù)

mysql中case when的作用是什么?這個(gè)問(wèn)題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過(guò)這個(gè)問(wèn)題能讓你收獲頗深。下面是小編給大家?guī)?lái)的參考內(nèi)容,讓我們一起來(lái)看看吧!

mysql case when的用法是:1、用作簡(jiǎn)單搜索,語(yǔ)法為【CASE [col_name] WHEN [value1]】;2、用作搜索,語(yǔ)法為【ASE WHEN [expr] THEN [result1]】。

mysql中case when的作用是什么

【相關(guān)學(xué)習(xí)推薦:mysql教程(視頻)】

mysql case when的用法是:

MySQL 的 case when 的語(yǔ)法有兩種:

簡(jiǎn)單函數(shù)

CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END

搜索函數(shù)

CASE WHEN [expr] THEN [result1]…ELSE [default] END

這兩種語(yǔ)法有什么區(qū)別呢?

簡(jiǎn)單函數(shù)

CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END: 枚舉這個(gè)字段所有可能的值*

SELECT
    NAME '英雄',
    CASE NAME
        WHEN '德萊文' THEN
            '斧子'
        WHEN '德瑪西亞-蓋倫' THEN
            '大寶劍'
        WHEN '暗夜獵手-VN' THEN
            '弩'
        ELSE
            '無(wú)'
    END '裝備'
FROM
    user_info;
復(fù)制代碼
復(fù)制代碼
SELECT
    NAME '英雄',
    CASE NAME
        WHEN '德萊文' THEN
            '斧子'
        WHEN '德瑪西亞-蓋倫' THEN
            '大寶劍'
        WHEN '暗夜獵手-VN' THEN
            '弩'
        ELSE
            '無(wú)'
    END '裝備'
FROM
    user_info;

搜索函數(shù)

CASE WHEN [expr] THEN [result1]…ELSE [default] END:搜索函數(shù)可以寫判斷,并且搜索函數(shù)只會(huì)返回第一個(gè)符合條件的值,其他case被忽略

# when 表達(dá)式中可以使用 and 連接條件
SELECT
    NAME '英雄',
    age '年齡',
    CASE
        WHEN age < 18 THEN
            '少年'
        WHEN age < 30 THEN
            '青年'
        WHEN age >= 30
        AND age < 50 THEN
            '中年'
        ELSE
            '老年'
    END '狀態(tài)'
FROM
    user_info;
聚合函數(shù) sum 配合 case when 的簡(jiǎn)單函數(shù)實(shí)現(xiàn)行轉(zhuǎn)列
SELECT
    st.stu_id '學(xué)號(hào)',
    st.stu_name '姓名',
    sum(
        CASE co.course_name
        WHEN '大學(xué)語(yǔ)文' THEN
            sc.scores
        ELSE
            0
        END
    ) '大學(xué)語(yǔ)文',
    sum(
        CASE co.course_name
        WHEN '新視野英語(yǔ)' THEN
            sc.scores
        ELSE
            0
        END
    ) '新視野英語(yǔ)',
    sum(
        CASE co.course_name
        WHEN '離散數(shù)學(xué)' THEN
            sc.scores
        ELSE
            0
        END
    ) '離散數(shù)學(xué)',
    sum(
        CASE co.course_name
        WHEN '概率論與數(shù)理統(tǒng)計(jì)' THEN
            sc.scores
        ELSE
            0
        END
    ) '概率論與數(shù)理統(tǒng)計(jì)',
    sum(
        CASE co.course_name
        WHEN '線性代數(shù)' THEN
            sc.scores
        ELSE
            0
        END
    ) '線性代數(shù)',
    sum(
        CASE co.course_name
        WHEN '高等數(shù)學(xué)' THEN
            sc.scores
        ELSE
            0
        END
    ) '高等數(shù)學(xué)'
FROM
    edu_student st
LEFT JOIN edu_score sc ON st.stu_id = sc.stu_id
LEFT JOIN edu_courses co ON co.course_no = sc.course_no
GROUP BY
    st.stu_id
ORDER BY
    NULL;

感謝各位的閱讀!看完上述內(nèi)容,你們對(duì)mysql中case when的作用是什么大概了解了嗎?希望文章內(nèi)容對(duì)大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI