最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

mysql case when的用法是什么

来源:动视网 责编:小采 时间:2020-11-09 06:51:07
文档

mysql case when的用法是什么

mysql case when的用法是什么:mysql case when的用法是:1、用作简单搜索,语法为【CASE [col_name] WHEN [value1]】;2、用作搜索,语法为【ASE WHEN [expr] THEN [result1]】。【相关学习推荐:mysql教程(视频)】mysql case when的用法是:MySQL 的 case
推荐度:
导读mysql case when的用法是什么:mysql case when的用法是:1、用作简单搜索,语法为【CASE [col_name] WHEN [value1]】;2、用作搜索,语法为【ASE WHEN [expr] THEN [result1]】。【相关学习推荐:mysql教程(视频)】mysql case when的用法是:MySQL 的 case


【相关学习推荐:mysql教程(视频)】

mysql case when的用法是:

MySQL 的 case when 的语法有两种:

简单函数

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

搜索函数

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

这两种语法有什么区别呢?

简单函数

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;

搜索函数

CASE WHEN [expr] THEN [result1]…ELSE [default] END:搜索函数可以写判断,并且搜索函数只会返回第一个符合条件的值,其他case被忽略

# 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培训栏目!

文档

mysql case when的用法是什么

mysql case when的用法是什么:mysql case when的用法是:1、用作简单搜索,语法为【CASE [col_name] WHEN [value1]】;2、用作搜索,语法为【ASE WHEN [expr] THEN [result1]】。【相关学习推荐:mysql教程(视频)】mysql case when的用法是:MySQL 的 case
推荐度:
标签: 使用 用法 mysql
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top