问题描述
- 用sql语句遍历一个表里异常(时间段内很大或者很小)的数据,并将异常数据修改成相应时间段前的数据
-
我有一张表,里面3字段id、time、value.
由于value中的部分值异常的大,我想批量修改数据,比如说4.1日-4.20日出现中出现异常大的数据,我想把异常大的数据修改成和他时间段(时间段前或者后)差不多的数据,请问下这个sql应该怎么写啊。我用游标的方法怎么实现。谢谢啊!
解决方案
不知道你的数据库是什么,用MS SQL SERVER示意
建表SQL如下
CREATE TABLE t1
(
[id] INT IDENTITY(1,1) PRIMARY KEY,
[time] DATETIME,
[value] INTEGER
)
初始数据SQL如下
INSERT INTO t1
SELECT '2015-4-24 10:00',100
UNION ALL
SELECT '2015-4-24 11:00',200
UNION ALL
SELECT '2015-4-24 12:00',10000
UNION ALL
SELECT '2015-4-24 13:00',150
UNION ALL
SELECT '2015-4-25 12:00',150
UNION ALL
SELECT '2015-4-25 13:00',150
UNION ALL
SELECT GETDATE(),100
要实现的目标SQL如下
UPDATE t1
SET [value]=t0.[v]
FROM (SELECT dateadd(d,datediff(d,t11.[time],'1900-1-1'),'1900-1-1') tm,avg(t11.[value]) [v]
FROM t1 t11
WHERE t11.value <=1000
GROUP BY dateadd(d,datediff(d,t11.[time],'1900-1-1'),'1900-1-1')) t0,t1
WHERE t1.[value] > 1000
AND dateadd(d,datediff(d,t1.[time],'1900-1-1'),'1900-1-1') = t0.tm
不知是否和你的情况类似
解决方案二:
修正一下,第三个SQL
UPDATE t1
SET [value]=t0.[v]
FROM (SELECT dateadd(d,datediff(d,'1900-1-1',t11.[time]),'1900-1-1') tm,avg(t11.[value]) [v]
FROM t1 t11
WHERE t11.value <=1000
GROUP BY dateadd(d,datediff(d,'1900-1-1',t11.[time]),'1900-1-1')) t0,t1
WHERE t1.[value] > 1000
AND dateadd(d,datediff(d,'1900-1-1',t1.[time]),'1900-1-1') = t0.tm
时间: 2024-08-02 18:08:41