Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

Find data for each day between the two dates using access and vba

Posted on 2014-02-14
9
Medium Priority
?
1,973 Views
Last Modified: 2014-03-10
Hi,
I was wondering if some one can help me.

I have attached sample access file. It has two tables.

The total used data recorded in table1 is by interval(from start date to end date)
I need to convert this data to see daily usage. From that I need to calculate daily usage data
total_used/date difference. Then I need to record that data for each day in a range((from start date to end date) to table2

For example first record in table1 is

ID_interval      text1      startdate      enddate         total_used
1                       1A             1/8/2013      4/2/2013          34578.28
2                        2B              4/3/2013      6/7/2013           3458
so the matching records in table2 should be:

day_id      day                          ID_interval      total_used
1             1/8/2013                     1              411.6461904761905 ( 34578.28/84)
2             1/9/2013                  1             411.6461904761905      
.
.
.
.
84            4/2/2013                1             411.6461904761905
85            4/3/2013                2             53.2(3458/65)
86            4/4/2013                2             53.2
........


Avould like to write a vba procedure to append the data to table2 automatically. Any help will be apreciated
test.accdb
0
Comment
Question by:maximyshka
  • 4
  • 3
  • 2
9 Comments
 
LVL 16

Expert Comment

by:Sheils
ID: 39860100
I could not download your database. I presume that you have a table with daily records and call it tablex for the sake of this exercise.

VBA Code

Dim strSQL as String

strSQL="Insert Into table2"
strSQL=" Select * from tablex inner join table1 on tablex. ID_interval= table1. ID_interval"
strSQL=strSQL & " where table1.startdate>[Insert Start Date] And table1.enddate >[Insert End Date]"

Currentdb.Execute strSQL

Open in new window

0
 

Author Comment

by:maximyshka
ID: 39860122
I'm not sure if you understood correctly.
Right now Imy data base stores data between two dates.
For example between 01/12/2014 - 01/15/2014 where used 16 units.
I need to convert it to daily usage
01/12/2014 - 4 units
01/13/2014 - 4 units
01/14/2014 - 4 units
01/15/2014 - 4 units

I need to do it for each record in a table.
0
 
LVL 120

Expert Comment

by:Rey Obrero (Capricorn1)
ID: 39860154
test this, see code in module1
open table2
test.accdb
0
VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

 
LVL 16

Expert Comment

by:Sheils
ID: 39860184
If you do not have the daily data recorded somewhere you can't get it simply because it is not there. You may be able to make it up assuming that the same amount was used in that interval.

So example  01/12/2014 - 01/15/2014  is 4 days. Then you divide 16 by 4 and assume that 4 units were used per day in that interval.

Is that what you have in mind.
0
 
LVL 16

Expert Comment

by:Sheils
ID: 39860195
still can't download. Please post a copy of the code
0
 

Author Comment

by:maximyshka
ID: 39860232
So example  01/12/2014 - 01/15/2014  is 4 days. Then you divide 16 by 4 and assume that 4 units were used per day in that interval.

that is true, this is my assumption.
0
 
LVL 120

Expert Comment

by:Rey Obrero (Capricorn1)
ID: 39860242
@maximyshka


did you test what i uploaded ?






.
0
 
LVL 16

Expert Comment

by:Sheils
ID: 39860343
Hi Rey,

Did you managed to download Max's sample db?

Max then I would use something like:-

Dim strSQL as String
Dim lngInterval as Long
Dim strInterval as String
Dim dteStart as Date
Dim dteEnd as Date
Dim dteDay as Date
Dim lngSum as Long

dteStart = Inputbox("Insert Start Date")
dteDay=dteStart

dteEnd = Inputbox("Insert End Date")

lngInterval=DateDiff(dteStart,dteStart)

lngSum = DSum("total_used","table1","startdate>#" & dteStart & "# AND enddate <#" & dteEnd & "#")


For i=0 to lngInterval - 1

      strInterval=DLookup("ID_interval","table1","startdate<#" & dteDay & "# AND enddate >#" & dteDay & "#"
      strSQL="Insert Into table2(" day,ID_interval,total_used)
      strSQL=strSQL & " VALUES(" & dteDay & "," & strInterval & "," & lngSum/lngInterval & ")"

      Currentdb.Execute strSQL
      dteDay=DateAdd("d", 1, dteDay)

Next
0
 
LVL 120

Accepted Solution

by:
Rey Obrero (Capricorn1) earned 2000 total points
ID: 39860401
here is my codes


Sub populateTable2()
Dim rs1 As DAO.Recordset, rs2 As DAO.Recordset
Dim j As Long, x As Long
Set rs1 = CurrentDb.OpenRecordset("table1")
Set rs2 = CurrentDb.OpenRecordset("table2")

rs1.MoveFirst

Do Until rs1.EOF
     j = DateDiff("d", rs1!startdate, rs1!enddate)
     For x = 1 To j
          With rs2
               .AddNew
               ![Day] = rs1!startdate + x - 1
               !id_interval = rs1!id_interval
               !total_used = rs1!total_used / j
               .Update
          End With
     Next
rs1.MoveNext
Loop

rs1.Close
rs2.Close
End Sub
0

Featured Post

Fill in the form and get your FREE NFR key NOW!

Veeam is happy to provide a FREE NFR server license to certified engineers, trainers, and bloggers.  It allows for the non‑production use of Veeam Agent for Microsoft Windows. This license is valid for five workstations and two servers.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Among the most obnoxious of Exchange errors is error 1216 – Attached Database Mismatch error of the Jet Database Engine. When faced with this error, users may have to suffer from mailbox inaccessibility and in worst situations, permanent data loss.
Beware when using the ListIndex and the Column() properties of a listbox in Access 2007.  A bug has been identified in the Access 2007 listbox code which can cause the .ListIndex property to return a -1, and the .Columns(#) property to return a NULL…
Despite its rising prevalence in the business world, "the cloud" is still misunderstood. Some companies still believe common misconceptions about lack of security in cloud solutions and many misuses of cloud storage options still occur every day. …
The Relationships Diagram is a good way to get an overall view of what a database is keeping track of. It is also where relationships are defined. A relationship specifies how two tables connect to each other. As you build tables in Microsoft Ac…
Suggested Courses

580 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