首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >错误代码: 1241。操作数应包含1列(S)

错误代码: 1241。操作数应包含1列(S)
EN

Database Administration用户
提问于 2018-03-22 17:16:02
回答 2查看 10.9K关注 0票数 -1

这是一个比较三个数字的程序,以找出最大的

代码语言:javascript
复制
INSERT INTO compare(a,b,c)
values(43,56,2);

SELECT a,b,c,
IF (a>b AND a>c,'a is greatest',
       (SELECT a,b,c,
       IF (b>c,'b is greatest','c is greatest')
       )
   )
AS  greatest           
FROM compare; 

错误:错误代码: 1241。操作数应包含1列(S),请说明错误的原因,以及如何improve.thanking每个人的帮助。

EN

回答 2

Database Administration用户

回答已采纳

发布于 2018-03-22 17:56:48

没有理由在第一个if语句之后选择第二次。只需在第一个if语句的其余部分进行b大于c的第二个测试即可。

代码语言:javascript
复制
SELECT a,b,c,
 IF (a>b AND a>c,'a is greatest',IF (b>c,'b is greatest','c is greatest'))
 AS  greatest           
 FROM test
票数 1
EN

Database Administration用户

发布于 2018-03-22 18:03:46

使用案例:

注意,我使用了整合(列)来避免a、b或c的空值,但我不知道哪个是最小允许值。

代码语言:javascript
复制
SELECT a, b, c,
       CASE WHEN (a > b OR b IS NULL) AND (a > c OR C IS NULL) THEN 'a is greatest'
            WHEN (b > C OR c IS NULL) THEN 'b is greatest
            ELSE 'c is greatest'
       END AS  greatest           
FROM compare; 
票数 1
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/202033

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档