(1) CASE value WHEN [compare-value] THEN result [WHEN [compare-value] THEN result ...] [ELSE result] END //这个我还没想到咋用,知道的可以留言交流, (2) CASE WHEN [condition] THEN result [WHEN [condition] THEN result ...] [ELSE result] END //这个面试时被人问到了,可以用作条件判断 第(1)个返回 result,其中value=compare-value。第(2)个中如果第一个条件为真,返回result。如果没有匹配的result值,那么结 果在ELSE后的result被返回。如果没有ELSE部分,那么NULL被返回。
mysql> SELECT CASE 1 WHEN 1 THEN "one" WHEN 2 THEN "two" ELSE "more" END; -> "one" mysql> SELECT CASE WHEN 1>0 THEN "true" ELSE "false" END; -> "true" mysql> SELECT CASE BINARY "B" when "a" then 1 when "b" then 2 END; -> NULL
上面的例子本人在mysql5.2.6上测试通过=====================================================================================PS:以上是转载的内容,觉得很不错就转过来了,其中的CASE...WHEN...THEN、IF、IFNULL都是常用到的函数eg:SELECT id,username,CASE gender WHEN 1 THEN "男" WHEN 2 THEN "女" END FROM t_people; SELECT b.id,b.book_name,CASE b.type WHEN 1 THEN "计算机" WHEN 2 THEN "会计" ELSE "其它" END FROM book b;