首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >是否可以使用HAVING子句执行delete?

是否可以使用HAVING子句执行delete?
EN

Stack Overflow用户
提问于 2012-07-29 09:44:51
回答 5查看 63.1K关注 0票数 40

我想做一些如下的事情:

代码语言:javascript
代码运行次数:0
运行
复制
DELETE UserPredictions
  GROUP BY UserId
  HAVING COUNT(*) < 500

但是我得到了一个语法错误。是否可以在SQL Server中使用HAVING子句执行delete操作,或者我是否必须将计数汇总到CTE中并使用join执行delete操作?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2012-07-29 09:52:29

不怎么有意思。having子句意味着聚合,这意味着您不再拥有原始行。

我认为你需要以下几点:

代码语言:javascript
代码运行次数:0
运行
复制
DELETE from UserPredictions
where UserId in (select UserId from UserPredictions group by UserId having count(*) < 500)
票数 53
EN

Stack Overflow用户

发布于 2012-07-29 10:57:33

可以在DELETE语句中使用联接的subselect:

代码语言:javascript
代码运行次数:0
运行
复制
DELETE a
FROM   UserPredictions a
JOIN
(
    SELECT   UserId
    FROM     UserPredictions
    GROUP BY UserId
    HAVING   COUNT(1) < 500
) b ON a.UserId = b.UserId

SQLFiddle Demo

票数 26
EN

Stack Overflow用户

发布于 2012-07-29 09:53:17

尝试此嵌套查询:

代码语言:javascript
代码运行次数:0
运行
复制
DELETE FROM UserPredictions  
WHERE UserId IN (SELECT UserId
                 FROM UserPredictions 
                 GROUP BY UserId
                 HAVING COUNT(*) < 500)
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11705996

复制
相关文章

相似问题

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