mysql - IF 条件错误 1241 (21000) : Operand should contain 1 column(s)

标签 mysql

如何修复?

 mysql> SELECT  IF(1,(SELECT * FROM zd LIMIT 1 ) ,(SELECT *  FROM zd LIMIT 3) );
ERROR 1241 (21000): Operand should contain 1 column(s)
mysql>

谢谢。

最佳答案

错误代码比一开始看起来更能提供信息。

Operand should contain 1 columns

在您的示例中,IF运算符,而1(SELECT * FROM zd LIMIT 1 )(SELECT * FROM zd LIMIT 3)操作数

IF 语句采用三个参数: bool 值、 bool 值为真时返回的标量 值和 bool 值为假时返回的标量值。

您的选择子查询各返回一行。您必须只返回一个值,如下所示:

SELECT IF(1,(SELECT col1_name FROM zd LIMIT 1 ) ,(SELECT col2_name  FROM zd LIMIT 1) )

col1_namecol2_name 替换为您要从中获取数据的任何列。

====

现在我再次阅读了您的问题,我明白您实际上想要做的是对限制进行条件化。如果可能的话,我会用 PHP 或任何你查询数据库的语言来做:

$limit = $bool ? 1 : 3;
$mysql->prepare("SELECT * FROM zd LIMIT $limit");
$mysql->execute();
$result = $mysql->fetch(PDO::FETCH_ASSOC)

我不确定是否有一种方法可以在没有变量的情况下有条件地在 mysql 中设置限制。

关于mysql - IF 条件错误 1241 (21000) : Operand should contain 1 column(s),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26923361/

相关文章:

java - org.quartz.JobPersistenceException : Couldn't acquire next trigger: Unknown column 'SCHED_TIME' in 'field list'

mysql - 无法显示不同表中的列

mysql - 我怎么知道客户是否在使用准备好的语句?

c# - WHERE 子句中使用的拆分 varchar 值

MySQL按记录组对行进行排序

mysql - 从 BLOB 更改为文件存储 - mySQL 调整

MySQL UNIX_TIMESTAMP(now()) - 当前时间(以毫秒为单位)

来自连接的 MySQL 列计数

mysql - SQL函数从同一列中获取1条静态记录和5条随机记录

php - 从 mysql DB 选择后如何向对象添加新属性