difference of date/time field

khawarameer

Board Regular
Joined
Jun 2, 2009
Messages
152
Dear All,

I have a table of 20000 records. Records have a datetime field. I want to select all records where gap between one record and subsequent record is more than one hour [condition to be applied on datetime field].

can any one please help.

regards

KAM
 
so you can check each record, though not necessarily "in order" -
Maybe I was wrong to assume the records had to be in chronological order, which is why my mindset was around ensuring an order first. That being said, your solution could be applied to a query (as a table) if that was a concern. I had to do something like this once where the in-out date/time fields related to each individual had to be compared to ensure there was a minimum gap between the out and the next in, plus ensure the total for the day didn't exceed 16 hrs for any individual, plus look for double payment - and the in-outs for an individual could overlap other individuals. I tend to gravitate to what I've done before, I guess. Here's my take on the vb approach, untested, unfinished, mostly due to not having the required information. I had in mind to output the result to a table instead of a virtual recordset in order to avoid having to use ADODB. It might be interesting to see which is faster, though I expect the sql version would be.

Code:
Private Sub TimeSpan()
Dim rsSource as DAO.Recordset, rsTarget As DAO.Recordset
Dim dteStart as Date, dteEnd as Date
On Error GoTo errHandler

Set rsTarget = CurrentDb.OpenRecordset("NameOfTable", dbOpenDynaSet)
Set rsSource = CurrentDb.OpenRecordset("NameOfSortingQuery")
rsSource.MoveFirst
Do While Not rsSource.EOF
  dteStart = rsSource.Fields("StartDate")
  rsSource.MoveNext
  dteEnd = rsSource.Fields("EndDate")
  If DateDiff("h",dteEnd, dteStart)>1 Then
    rsSource.MovePrevious
    rsTarget.AddNew
    rsTarget!RecID = rsSource.Fields("RecID")
    'add additional fields as required
    rsTarget.Update
    rsSource.MoveNext
    rsTarget.AddNew
    rsTarget!RecID = rsSource.Fields ("RecID")
    rsTarget.Update
  End If
Loop

exitHere:
rsTarget.Close 
rsSource.Close
Set rsTarget = Nothing
Set rsSource = Nothing
Exit Sub

errHandler:
msgbox "Error " & Err.Number & ": " & Err.Description
Resume exitHere
End Sub
 
Upvote 0

Excel Facts

Workdays for a market open Mon, Wed, Friday?
Yes! Use "0101011" for the weekend argument in NETWORKDAYS.INTL or WORKDAY.INTL. The 7 digits start on Monday. 1 means it is a weekend.

Forum statistics

Threads
1,225,726
Messages
6,186,676
Members
453,368
Latest member
xxtanka

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top