微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQL Server子查询返回了多个值当子查询后跟字符或将子查询用作表达式时,这是不允许的

如何解决SQL Server子查询返回了多个值当子查询后跟字符或将子查询用作表达式时,这是不允许的

使用IN关键字而不是等于运算符,如下所示:

UPDATE table1
SET statusField = 1
WHERE someID IN (
           SELECT someID
           FROM table1
           GROUP BY someID HAVING COUNT(*) = 1
           )

使用=要求子查询返回恰好1个结果。IN关键字适用于列表。

解决方法

我正在尝试根据它们的出现来更新某些字段。如果它们只发生一次,我将更新一些状态字段。

我当前的代码如下:

UPDATE table1
SET statusField = 1
WHERE someID = (
               SELECT someID
               FROM table1
               GROUP BY someID HAVING COUNT(*) = 1
               )

这将返回类似于标题中的错误的错误: Subquery returned more than 1 value. This is not permitted when the subquery follows =,!=,<,<=,>,>= or when the subquery is used as an expression.

是否有其他易于理解/简单的解决方案?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。