mysql case 问题

2019-06-10 10:24:47 +08:00
 zxcjqyy

case 字段名 when 和 case when 有什么区别

1150 次点击
所在节点    程序员
2 条回复
Semoz
2019-06-10 11:47:06 +08:00
CASE type WHEN 1 THEN 'a' WHEN 2 THEN 'b' ELSE 'c' END

CASE WHEN type > 5 THEN 'd' WHEN type < 0 THEN 'e' ELSE 'f' END

你说啥区别?
zxcjqyy
2019-06-10 14:13:08 +08:00
SELECT (CASE
WHEN MOD(id,2) = 1 AND id = (SELECT COUNT(*) FROM seat) THEN id
WHEN MOD(id,2) = 1 THEN id+1
ElSE id-1
END) AS id, student
FROM seat
ORDER BY id;


select (case id when mod(id,2)=1 and id = (select count(*) from seat) then id
when mod(id,2)=1 then id+1
else id-1
end)id, student
from seat
order by id

那这 2 个 sql 结果为什么会不一样

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/572339

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX