繁体   English   中英

SQL删除基于多列的行

[英]SQL Delete Rows Based on Multiple Columns

我有一个包含八列的表格,包括设备 ID、设备读取类型和设备读取日期。 这三列看起来像这样:示例表

我想要做的是删除 DevReadType = XX 的每一行以及具有匹配 DevNum 但 DevReadDate 小于 DevReadType = 'XX' 的日期的每一行。 我一直找不到这种复杂条件的任何例子。 帮助将不胜感激!

delete from device
   where  DevNum = @devicenum
   and    DevReadType = 'XX'
   and    DevReadDate < @date

您可以通过首先运行 selectagainsr 设备表来测试您的 where 子句:

select * 
from device
    where  DevNum = @devicenum
    and    DevReadType = 'XX'
    and    DevReadDate < @date

如果我理解正确,我会建议以下内容:

DELETE  d
FROM device d
JOIN (
    SELECT DevNum, MAX(DevReadDate) maxDevReadDate
    FROM device
    WHERE devReadType = 'xx'
    GROUP BY DevNum
) b
ON d.DevNum = b.DevNum AND (d.DevReadDate < b.maxDevReadDate OR d.devReadType = 'xx')

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM