吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1984|回复: 15
收起左侧

[求助] 学习MySQL遇到了Case函数的问题

[复制链接]
thepoy 发表于 2019-7-6 12:22
image.png


“评分”除了9.5的返回正确结果,其他都不正确,这是哪里写错了呢?
[SQL] 纯文本查看 复制代码
SELECT 电影名,导演,评分, 
CASE 评分 
WHEN 9.6 THEN 3  
WHEN 9.5 THEN 2
WHEN 9.4 THEN 1
WHEN 9.3 THEN 0 
ELSE -1 
END AS 水平 
FROM movies;

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

as849167276 发表于 2019-7-6 12:36
看看  elseif  
as849167276 发表于 2019-7-6 12:37
zyl5664 发表于 2019-7-6 12:39
首先你这是mariaDB 称为mysql的话也不算错。其次你这个中文列名看着是真的...开发的确没见过,然后我也不知道你这为啥case when 有问题
 楼主| thepoy 发表于 2019-7-6 12:44
zyl5664 发表于 2019-7-6 12:39
首先你这是mariaDB 称为mysql的话也不算错。其次你这个中文列名看着是真的...开发的确没见过,然后我也不知 ...

中文列名是我试着玩的
 楼主| thepoy 发表于 2019-7-6 12:45
zyl5664 发表于 2019-7-6 12:39
首先你这是mariaDB 称为mysql的话也不算错。其次你这个中文列名看着是真的...开发的确没见过,然后我也不知 ...

deepin apt mysql安装完后就是mariaDB,安装完我也有点懵逼
烽火戏諸侯 发表于 2019-7-6 14:03
case  when  charindex('9.6',评分)>0 then '3'
else 评分
end  as  水平
类似于这样

我这个是sql server  的写法
我查询了一下资料,mysql 应该是可以的
繁花落尽秭归陈 发表于 2019-7-6 14:29
本帖最后由 繁花落尽秭归陈 于 2019-7-6 14:42 编辑

齐了怪了  
 楼主| thepoy 发表于 2019-7-6 15:09
烽火戏諸侯 发表于 2019-7-6 14:03
case  when  charindex('9.6',评分)>0 then '3'
else 评分
end  as  水平

没学完,还不知道charindex是什么意思,但是当我把字段移到when里面时,就能正常执行了。
不知道你用sql的时候,字段放在case后面是否能够正常执行

[SQL] 纯文本查看 复制代码
SELECT 电影名, 导演, 
CASE 
WHEN 评分=9.6 THEN 3 
WHEN 评分=9.5 THEN 2 
WHEN 评分=9.4 THEN 1 
WHEN 评分=9.3 THEN 0 
ELSE -1 
END AS 水平 
FROM movies;
 楼主| thepoy 发表于 2019-7-6 15:10

咋了,你怎么还把回复编辑了
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-27 04:15

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表