Solved

SQL update matching first record with closest time

Posted on 2009-05-15
2
505 Views
Last Modified: 2012-06-27
Hi
I have following sample data in different tables
HistorianData
     TIMESTAMP                  FieldX
1   15/10/08  00:00:00     NULL
2   15/10/08  00:01:00     NULL
3   15/10/08  00:02:00     NULL
...
X     15/10/09  23:59:00     NULL
X+1 16/10/09  00:00:00     NULL
X+2  16/10/09 00:01:00     NULL
XXX...      16/10/09  00:02:00

and so on...a date/time field with every minute and 0 seconds

I have another table DataDump with data like this

       TIMESTAMP                  FieldX
9     15/10/08  00:00:10       1
10   15/10/08  00:00:20       2
11   15/10/08  00:00:40       90
12   16/10/08  00:01:16       64
13   16/10/08  00:01:59       20
...
X     16/10/08  00:02:20       123


I want to set the FieldX of HistorianData to be FieldX of DataDump . Because in DataDump the TIMESTAMP isn't rounded down every minute so often there are not exact matches with HistorianData.
In the match I want to round the first record of every minute DOWN so that there is always a match, so in above I want

1 would be set to record ID 9
2 would be set to record ID 12
XXX would be set to record ID X

There are more than one record per minute in DataDump , I only want to match the closest record and ignore others.

Thanks in advance for help with transact-SQL.  If it helps, any records of TableX records can be deleted or modified, it will just be deleted anyway after update.

I have SQL server 2008

(I know TIMESTAMP isn't a good field name, please excuse it, but that's what data dump was....)
I used following SQL kindly made up on another question for EXACT matches...
 

update HistorianData set [ddd] = D.[ddd]

  from [DataDump] D

 where HistorianData.[TIMESTAMP] = D.[DataDump]

Open in new window

0
Comment
Question by:rwallacej
2 Comments
 
LVL 142

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 500 total points
ID: 24394210
something like this should do:
UPDATE t1

  SET fieldx = ( SELECT TOP 1 t2.Fieldx 

                 FROM table2 t2 

                 WHERE t2.TIMESTAMP >= DATEADD(minute, -1, t1.TIMESTAMP )

                   AND t2.TIMESTAMP <= DATEADD(minute, 1, t1.TIMESTAMP )

                )

Open in new window

0
 

Author Closing Comment

by:rwallacej
ID: 31581821
thank-you - this works
regards,
rwallacej
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

In this article I will describe the Copy Database Wizard method as one possible migration process and I will add the extra tasks needed for an upgrade when and where is applied so it will cover all.
Use this article to create a batch file to backup a Microsoft SQL Server database to a Windows folder.  The folder can be on the local hard drive or on a network share.  This batch file will query the SQL server to get the current date & time and wi…
This video discusses moving either the default database or any database to a new volume.
Illustrator's Shape Builder tool will let you combine shapes visually and interactively. This video shows the Mac version, but the tool works the same way in Windows. To follow along with this video, you can draw your own shapes or download the file…

747 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now