gpt4 book ai didi

sql - 删除每第 n 行 SQL

转载 作者:太空狗 更新时间:2023-10-30 01:42:11 25 4
gpt4 key购买 nike

假设我有一个包含 1000 行的表(id int,Name varchar)。现在我想删除每第 n 个记录(每第 2、3 或 5)。最有效的方法是什么?

最佳答案

对于 SQL Server 2005+

每第二行

WITH example AS (
SELECT t.*, ROW_NUMBER() OVER (ORDER BY t.id) AS rank
FROM TABLE t)
DELETE example
WHERE rank%2 = 0

对于每第 3 行,将 WHERE 子句更改为:

WHERE rank%3 = 0

每第五行的 Anf:

WHERE rank%5 = 0

这使用模数,它返回除法的余数。如果余数为零,则被除数是除数的倍数。

关于sql - 删除每第 n 行 SQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3509094/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com