我有一张表,里面3字段id、time、value.
由于value中的部分值异常的大,我想批量修改数据,比如说4.1日-4.20日出现中出现异常大的数据,我想把异常大的数据修改成和他时间段(时间段前或者后)差不多的数据,请问下这个sql应该怎么写啊。我用游标的方法怎么实现。谢谢啊!
用sql语句遍历一个表里异常(时间段内很大或者很小)的数据,并将异常数据修改成相应时间段前的数据
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 知常曰明 2015-04-24 23:06关注
修正一下,第三个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
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报