开发者社区> 科技小先锋> 正文

MySQL 的CASE WHEN 语句使用说明

简介:
+关注继续查看

MySQL 的CASE WHEN 语句使用说明,需要的朋友可以参考下。

使用CASE WHEN进行字符串替换处理


  1.  
  2. /*   
  3. mysql> select * from sales;   
  4. +-----+------------+--------+--------+--------+------+------------+   
  5. | num | name | winter | spring | summer | fall | category |   
  6. +-----+------------+--------+--------+--------+------+------------+   
  7. | 1 | Java | 1067 | 200 | 150 | 267 | Holiday |   
  8. | 2 | C | 970 | 770 | 531 | 486 | Profession |   
  9. | 3 | JavaScript | 53 | 13 | 21 | 856 | Literary |   
  10. | 4 | SQL | 782 | 357 | 168 | 250 | Profession |   
  11. | 5 | Oracle | 589 | 795 | 367 | 284 | Holiday |   
  12. | 6 | MySQL | 953 | 582 | 336 | 489 | Literary |   
  13. | 7 | Cplus | 752 | 657 | 259 | 478 | Literary |   
  14. | 8 | Python | 67 | 23 | 83 | 543 | Holiday |   
  15. | 9 | PHP | 673 | 48 | 625 | 52 | Profession |   
  16. +-----+------------+--------+--------+--------+------+------------+   
  17. rows in set (0.01 sec)   
  18. mysql> SELECT name AS Name,   
  19. -> CASE category   
  20. -> WHEN "Holiday" THEN "Seasonal"   
  21. -> WHEN "Profession" THEN "Bi_annual"   
  22. -> WHEN "Literary" THEN "Random" END AS "Pattern"   
  23. -> FROM sales;   
  24. +------------+-----------+   
  25. Name | Pattern |   
  26. +------------+-----------+   
  27. | Java | Seasonal |   
  28. | C | Bi_annual |   
  29. | JavaScript | Random |   
  30. | SQL | Bi_annual |   
  31. | Oracle | Seasonal |   
  32. | MySQL | Random |   
  33. | Cplus | Random |   
  34. | Python | Seasonal |   
  35. | PHP | Bi_annual |   
  36. +------------+-----------+   
  37. rows in set (0.00 sec)   
  38. */   
  39. Drop table sales;   
  40. CREATE TABLE sales(   
  41. num MEDIUMINT NOT NULL AUTO_INCREMENT,   
  42. name CHAR(20),   
  43. winter INT,   
  44. spring INT,   
  45. summer INT,   
  46. fall INT,   
  47. category CHAR(13),   
  48. primary key(num)   
  49. )type=MyISAM;   
  50. insert into sales value(1, 'Java', 1067 , 200, 150, 267,'Holiday');   
  51. insert into sales value(2, 'C',970,770,531,486,'Profession');   
  52. insert into sales value(3, 'JavaScript',53,13,21,856,'Literary');   
  53. insert into sales value(4, 'SQL',782,357,168,250,'Profession');   
  54. insert into sales value(5, 'Oracle',589,795,367,284,'Holiday');   
  55. insert into sales value(6, 'MySQL',953,582,336,489,'Literary');   
  56. insert into sales value(7, 'Cplus',752,657,259,478,'Literary');   
  57. insert into sales value(8, 'Python',67,23,83,543,'Holiday');   
  58. insert into sales value(9, 'PHP',673,48,625,52,'Profession');   
  59. select * from sales;   
  60. SELECT name AS Name,   
  61. CASE category   
  62. WHEN "Holiday" THEN "Seasonal"   
  63. WHEN "Profession" THEN "Bi_annual"   
  64. WHEN "Literary" THEN "Random" END AS "Pattern"   
  65. FROM sales;  

简单语句


  1.  
  2. SELECT CASE WHEN 10*2=30 THEN '30 correct'   
  3. WHEN 10*2=40 THEN '40 correct'   
  4. ELSE 'Should be 10*2=20'   
  5. END;  

多重表达式


  1. SELECT CASE 10*2   
  2. WHEN 20 THEN '20 correct'   
  3. WHEN 30 THEN '30 correct'   
  4. WHEN 40 THEN '40 correct'   
  5. END;  

在SELECT查询中使用CASE WHEN


  1.  
  2. /*   
  3. mysql> SELECT Name, RatingID AS Rating,   
  4. -> CASE RatingID   
  5. -> WHEN 'R' THEN 'Under 17 requires an adult.'   
  6. -> WHEN 'X' THEN 'No one 17 and under.'   
  7. -> WHEN 'NR' THEN 'Use discretion when renting.'   
  8. -> ELSE 'OK to rent to minors.'   
  9. -> END AS Policy   
  10. -> FROM DVDs   
  11. -> ORDER BY Name;   
  12. +-----------+--------+------------------------------+   
  13. Name | Rating | Policy |   
  14. +-----------+--------+------------------------------+   
  15. | Africa | PG | OK to rent to minors. |   
  16. | Amadeus | PG | OK to rent to minors. |   
  17. | Christmas | NR | Use discretion when renting. |   
  18. | Doc | G | OK to rent to minors. |   
  19. | Falcon | NR | Use discretion when renting. |   
  20. | Mash | R | Under 17 requires an adult. |   
  21. | Show | NR | Use discretion when renting. |   
  22. View | NR | Use discretion when renting. |   
  23. +-----------+--------+------------------------------+   
  24. rows in set (0.01 sec)   
  25. */   
  26. Drop table DVDs;   
  27. CREATE TABLE DVDs (   
  28. ID SMALLINT NOT NULL AUTO_INCREMENT PRIMARY KEY,   
  29. Name VARCHAR(60) NOT NULL,   
  30. NumDisks TINYINT NOT NULL DEFAULT 1,   
  31. RatingID VARCHAR(4) NOT NULL,   
  32. StatID CHAR(3) NOT NULL   
  33. )   
  34. ENGINE=INNODB;   
  35. INSERT INTO DVDs (Name, NumDisks, RatingID, StatID)   
  36. VALUES ('Christmas', 1, 'NR''s1'),   
  37. ('Doc', 1, 'G''s2'),   
  38. ('Africa', 1, 'PG''s1'),   
  39. ('Falcon', 1, 'NR''s2'),   
  40. ('Amadeus', 1, 'PG''s2'),   
  41. ('Show', 2, 'NR''s2'),   
  42. ('View', 1, 'NR''s1'),   
  43. ('Mash', 2, 'R''s2');   
  44. SELECT Name, RatingID AS Rating,   
  45. CASE RatingID   
  46. WHEN 'R' THEN 'Under 17 requires an adult.'   
  47. WHEN 'X' THEN 'No one 17 and under.'   
  48. WHEN 'NR' THEN 'Use discretion when renting.'   
  49. ELSE 'OK to rent to minors.'   
  50. END AS Policy   
  51. FROM DVDs   
  52. ORDER BY Name;  

 


本文转自sucre03 51CTO博客,原文链接:http://blog.51cto.com/sucre/910501,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
29211 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
20725 0
使用 NodeJS+Express+MySQL 实现简单的增删改查
关于node.js暂时记录如下,以后有时间一定学习 文章来自简书,作者:sprint,2016-07 使用 Node.js + Express+MySQL 实现简单的增删改查 https://www.jianshu.
2606 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
23589 0
为什么 MySQL 不推荐使用 join?
1.对于mysql,不推荐使用子查询和join是因为本身join的效率就是硬伤,一旦数据量很大效率就很难保证,强烈推荐分别根据索引单表取数据,然后在程序里面做join,merge数据。
23 0
HBase基本操作-shell使用
这篇在学习之前,需要搭建好HBase集群,当你的集群搭建好了,那么就开始学习HBase的shell操作把~ 这篇文章将只会介绍使用频率最高的shell命令,这些没有什么难度,只是一些熟练问题,我的HBase版本是 进入HBase的命令行的命令是HBase shell 查看HBase shell中.
7101 0
6965
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载