ホームページ >データベース >mysql チュートリアル >mysql case はどのような場合に使用するのですか?
mysql case の使用法は次のとおりです: 1. 単純な検索として使用され、構文は [CASE [col_name] WHEN [value1]]; 2. 検索関数として使用され、構文は [CASE WHEN] [式] THEN [結果1]]。
【関連する学習の推奨事項: mysql チュートリアル(ビデオ)】
mysql case when の使用法は次のとおりです:
case when には 2 つの構文があります
単純な関数
CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END
検索関数
CASE WHEN [expr] THEN [result1]…ELSE [default] END
これら 2 つの構文の違いは何ですか?
1. 単純な関数
CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END
このフィールドの可能な値をすべて列挙します*
SELECT NAME '英雄', CASE NAME WHEN '德莱文' THEN '斧子' WHEN '德玛西亚-盖伦' THEN '大宝剑' WHEN '暗夜猎手-VN' THEN '弩' ELSE '无' END '装备' FROM user_info; 复制代码 复制代码 SELECT NAME '英雄', CASE NAME WHEN '德莱文' THEN '斧子' WHEN '德玛西亚-盖伦' THEN '大宝剑' WHEN '暗夜猎手-VN' THEN '弩' ELSE '无' END '装备' FROM user_info;
2. 検索関数
CASE WHEN [expr] THEN [result1]…ELSE [default] END
検索関数は判定を書き込むことができ、検索関数は条件を満たす最初の値のみを返し、その他の場合は無視されます
# when 表达式中可以使用 and 连接条件 SELECT NAME '英雄', age '年龄', CASE WHEN age < 18 THEN '少年' WHEN age < 30 THEN '青年' WHEN age >= 30 AND age < 50 THEN '中年' ELSE '老年' END '状态' FROM user_info;
聚合函数 sum 配合 case when 的简单函数实现行转列 SELECT st.stu_id '学号', st.stu_name '姓名', sum( CASE co.course_name WHEN '大学语文' THEN sc.scores ELSE 0 END ) '大学语文', sum( CASE co.course_name WHEN '新视野英语' THEN sc.scores ELSE 0 END ) '新视野英语', sum( CASE co.course_name WHEN '离散数学' THEN sc.scores ELSE 0 END ) '离散数学', sum( CASE co.course_name WHEN '概率论与数理统计' THEN sc.scores ELSE 0 END ) '概率论与数理统计', sum( CASE co.course_name WHEN '线性代数' THEN sc.scores ELSE 0 END ) '线性代数', sum( CASE co.course_name WHEN '高等数学' THEN sc.scores ELSE 0 END ) '高等数学' 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;
もっと知りたい プログラミング学習は、php trainingのコラムに注目してください!
以上がmysql case はどのような場合に使用するのですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。