Queries :: Selecting Latest Row For Each Year
			Dec 18, 2014
				I'm having trouble with a simple query.  They have an access database with a table like this (simplified for this example):
--------------------------------
Name    Result      Date
--------------------------------
Bob       5             1/1/2014
Bob       6             2/2/2014*
Bob       7             3/3/2015
Bob       8             5/4/2015*
Len       5             1/1/2014
Len       6             2/2/2014*
Len       7             3/3/2015
Len       5             7/4/2015*
---------------------------------
how I would write a query that gives me the latest result that each person earned in each year (I put a * symbol against the rows above that I am talking about)?
Bob        6        2/2/2014
Bob        8        5/4/2015
Len        6        2/2/2014
Len        5        7/4/2015
(The database is normalised and this table has an ID field).
	
	View Replies
  
    
	ADVERTISEMENT
    	
    	Oct 19, 2007
        
        Hello All
I have a number of Select queries that select 1st quarter up to 4th quarter of the year for accounting purposes. These are quite simple queries such as:
between "10" and "24" entered in the Criteria window. 10 and 24 being week numbers.
However if I wish to randomly select the week numbers after the query is loaded what is the correct code?
Regards
Terence
London
	View 3 Replies
    View Related
  
    
	
    	
    	Oct 19, 2007
        
        Hello All
I have a number of Select queries that select 1st quarter up to 4th quarter of the year for accounting purposes. These are quite simple queries such as:
between "10" and "24" entered in the Criteria window. 10 and 24 being week numbers.
However if I wish to randomly select the week numbers after the query is loaded what is the correct code?
Regards
Terence
London
	View 3 Replies
    View Related
  
    
	
    	
    	Jul 3, 2014
        
        I have fields [DayOfYear] and [Year] can I somehow produce the dd/mm/yyyy from this. I know how to do it in Excel but the Asscess function Date() is a little different.
 
I.e. if [DayOfYear] =152, [Year] = 2014 then [Date] = 2/6/2014
	View 6 Replies
    View Related
  
    
	
    	
    	Mar 23, 2013
        
        I have a table of SOPs/WIs. Each, with time, gets a new version  - this I keep in the child table.
tblVersions
------------
VersionID (PK)
SOPID(FK)
Version (integer)
IssueDate (date)
I want to make a list of the currently valid versions, i.e. for each SOPID pick the VersionID with the latest date.
One can do many things with subqueries and Max - functions, but after some experimentation I have stumbled upon this: 
Code:
SELECT Last(tblTest.VersionID) AS LastOfVersionID
FROM tblTest
WHERE (((tblTest.IssueDate)<Date()-10))
GROUP BY tblTest.SOPID;
The function Last has a bit tricky reputation and description on the web. It does yields the right result in my testcase though , see the attached db - run query3. 
Query3    
Code:
LastOfVersionID 
100     
90     
20     
40     
666     
888     
55     
8
Update:
Well, it isn't. Just changing the VersionID numbers to something other than an ascending sequence renders an incorrect result with the above query.  So what is the best way to get the desired result? (Access 2007)
	View 4 Replies
    View Related
  
    
	
    	
    	Dec 22, 2014
        
        I have a query with a record id, report date and status.
 
How do I pull the latest record if the status is AA?
 
For latest record in report date I used Max in Totals. With just this max it is pulling the latest date for each set of records with the same record id. 
 
This is a start now how do i pull the latest record that has a AA status?
	View 14 Replies
    View Related
  
    
	
    	
    	Jan 18, 2014
        
        I have a list of project, each of which have dates which work were carried out on them. Each project can have more than one date. I want to be able to find the last date that any work was carried out, and then calculate how many days have passed since that happened.
	View 6 Replies
    View Related
  
    
	
    	
    	May 29, 2014
        
        I have two tables.  The first is called Drawing Register and contains the fields Drawing No (primary field) and Drawing Title.The second table is the Drawing Register Details table which contains the fields Drawing No (joined field - Drawing Register table), Revision, Revision Notes, Date Issued.
I have a query and report which will list all the revisions for each drawing.  This is very important and useful.  However I want a summary report which will only show the last revision for each drawing.
I copied the original query, turned on the Totals option and under the Date Issued field changed Group by to Max.  However it is still returning all results for each drawing instead of only the last issue date for each drawing.
	View 14 Replies
    View Related
  
    
	
    	
    	Jun 19, 2013
        
        I need to find the latest number using a query.
All of the numbers follow this format:
[Doc No]
ABCD123
but the tricky part is the number could be suffixed with a revision.  It is the latest revision I would like to find.  For example, If I have a number followed by 3 revisions I would have:
[Doc No]
ABCD123
ABCD123+200
ABCD123+300
ABCD123+400
I need a query to give me the latest revision, in this case 
[Doc No]
ABCD123+400
There is a possibility there are no revisions in which case the latest will be
[Doc No]
ABCD123.
How is this possible in a query???  
	View 5 Replies
    View Related
  
    
	
    	
    	Feb 23, 2014
        
        I'm trying to create in access2010 
 (1) a query that returns the latest record (newest) in a table called 'Invoices' and then
 (2) places this value in a form called 'FrmInputInvoices' as the default value when the form opens. Newest record is by Autonumber and the table defaults this to top of table as views newest down to oldest.
 Re (1) Query is called 'QInvoices'; the values I want to return in my query is ID (my autonumber) and Invoice_No . Must be a simple answer to put in the criteria, but I can't find this.
 Re(2) What code do I use in my Form field named 'Invoice_No when the curser defaults there on opening?
	View 4 Replies
    View Related
  
    
	
    	
    	May 29, 2015
        
        Giving up after a zillion tries.  I have a table (tblLOADS) containing: BROKER, PUDATE, MATERIAL & DRIVER.  I am able to create this query:
  
 SELECT tblLOADS.L_ID, tblLOADS.BROKER, Max(tblLOADS.Pudate) AS MaxOfPudate, tblLOADS.Material, tblLOADS.Driver
FROM tblLOADS
GROUP BY tblLOADS.L_ID, tblLOADS.BROKER, tblLOADS.Material, tblLOADS.Driver
HAVING (((Max(tblLOADS.Pudate))>0));
  
 Problem: It's datasheet view displays all of the records for BROKERS, PUDATE, MATERIAL & DRIVER, instead of ONLY the records for  the last PUDATE of each of the BROKERS, with their corresponding MATERIAL & DRIVER fields.
	View 12 Replies
    View Related
  
    
	
    	
    	Jul 27, 2013
        
        My table appears like this with the following columns:
Name| CUSTNo| ORderNo.| AcctDate| OrderDate| OrderDescription
I would like to write a ms-sql query to return the records of each  customer number with the latest OrderDate. One more thing, if the  customer has two separate order numbers on the same date(should be the  latest date), the query should be able to pull up both the records. 
I tried with the code below but its taking a long time to execute and finally hanging up MS ACCESS.
SELECT * FROM TableName AS a WHERE Not Exists (SELECT *                  
FROM TableName b WHERE b.CUSTNo = a.CUSTNo AND b.OrderDate >= a.OrderDate);
	View 2 Replies
    View Related
  
    
	
    	
    	Mar 12, 2014
        
        I have a table that contains readings from several pieces of equipment as well as the status of each one. Each record has a timestamp, equipment number, status, etc. What I want is to create a query that will return the latest record for each equipment number. Simplified example table:
 
Timestamp EquipmentNumber Status
Today ------Machine1 ----------Running
Today ------Machine2 ----------Running
Yesterday -Machine1 ----------Down
Yesterday -Machine2 ----------Running
 
There are more than 20 different Equipment numbers and they are read several times per day and sometimes some of them get missed. What I'm looking for is a way to get a list of all the machines with their latest reading so they can tell which machines are running and which are down based on the last time they were read (instead of specifying a date). I can get this for one machine with no problem. I'm having trouble getting it for more than one machine. I tried a union query (with just 2 of the machines included for testing) but it only returns the results from one machine:
Code:
 
SELECT TOP 1 TestCompressorRoundQuery.LoggedAt,  TestCompressorRoundQuery.AssetNumber,  
TestCompressorRoundQuery.CompressorID, TestCompressorRoundQuery.Status, TestCompressorRoundQuery.CompressorIntegrity, TestCompressorRoundQuery.Notes
FROM TestCompressorRoundQuery
WHERE (((TestCompressorRoundQuery.AssetNumber)="104399"))
UNION ALL
[Code] ....
I'd rather not have to create a seperate query for each machine and then join all of those together! I think perhaps a Union query might not be the correct approach. All the data is coming from only one table.
	View 6 Replies
    View Related
  
    
	
    	
    	Nov 23, 2014
        
        How do I query from this table:
ORIGINAL_table
FName   |   END_Date|
--------|---------------|
John| Oct 09, 2014|
John| Oct 15, 2014|
John| Oct 25, 2014|
Mike| Dec 10, 2014|
Mike| Dec 15, 2014|
Mike| Dec 20, 2014|
Mike| Dec 25, 2014|
Jimm| Dec 10, 2014|
Jimm| Dec 15, 2014|
Jimm| Dec 20, 2014|
Alex| Dec 01, 2014|
Alex| Dec 05, 2014|
Alex| Dec 10, 2014|
Thom| Nov 10, 2014|
Thom| Oct 10, 2014|
Thom| Aug 10, 2014|
The output will be:
FName   |   END_Date|
----------|---------------|
John| Oct 25, 2014|
Mike| Dec 25, 2014|
Jimm| Dec 20, 2014|
Alex| Dec 10, 2014|
Thom| Nov 10, 2014|
The query table(output) will just have to be  latest date("END_Date") per "FName"
	View 1 Replies
    View Related
  
    
	
    	
    	Apr 26, 2013
        
        I try to make a query that can show me data from the lastest and max date from the table i have ( see attchment file )
I try using max but still the result is not what i am looking for...
	View 6 Replies
    View Related
  
    
	
    	
    	Jul 11, 2015
        
        If I have four date Fields in a query, Astart, Bstart, Cstart, and Dstart and want to have a calculated field to find the latest date for each record how would I do that? I have tried things like:
 
LatestDate: MAX(Astart, Bstart, Cstart, Dstart).
	View 2 Replies
    View Related
  
    
	
    	
    	May 7, 2014
        
        I have a table of accounts and a table of rates. There is a one-to-many relationship between them (i.e. each account can have multiple rates, each with their own - unique - effective date)
 
I'm trying to build a query which will show me all of the accounts in the accounts table and the most recent rate (based on the effective date) for each of those accounts.
 
This is as far as I've gotten with the SQL :
 
Code:
SELECT [tblAccounts].[AccountID], [tblAccounts].[AccountNumber], [tblAccounts].[AccountName], [LatestRate].[IntRate], [LatestRate].[EffectiveDate]
FROM [tblAccounts] 
LEFT JOIN 
    (SELECT TOP 1 [tblRates].[AccountID], [tblRates].[IntRate], [tblRates].[EffectiveDate]
     FROM [tblRates]
     ORDER BY [tblRates].[EffectiveDate] DESC) AS LatestRate 
ON [tblAccounts].[AccountID] = [LatestRate].[AccountID]
But this can't work because the [LatestRate] subquery can only ever return one record (i.e. the most recent rate across all of the accounts)
 
I need the most recent rate for each of the accounts in the main query
 
(FYI - I use an outer join as it is possible for no rate to be available in the rates table for a given account, in which case I want to return the null value rather than omit the account from the resulting dataset...)
	View 2 Replies
    View Related
  
    
	
    	
    	Feb 17, 2015
        
        I have a list of archive folders with unquie IDs and images files which have a version history.
 
I need to remove the history and just keep the latest archive version set of files. It seems an append query would be best but just can't think the best way todo it.
 
Table Example:
 
Archive:   Folder:                     User:      SubFolder:   Filename:
 
01           TA05420010125-01    8769091  WAG         20010125-01.tif
01           TA05420010125-01    8769091  TIM          20010125-02.tif
02           TA05420110324-01    8769091  WAG         20110324-01.tif
02           TA05420110324-01    8769091  TIM          2011032402.tif 
02           TA05420110324-01    8769091   PD           20110324-02.tif
03           TA05420150114-01    8769091  VYE          20010125-01.tif 
03           TA05420150114-01    8769091  DFU          20010125-02.tif  
 
In the above example I only want to keep user 8769091 latest filename info from archive 3 and exclude the rest.  I need todo this for over 3000 users who could have multiple versions. 
	View 5 Replies
    View Related
  
    
	
    	
    	May 19, 2015
        
        I am trying to find the latest date in a table where the dates are in 2 separate columns and multiple rows. (there are business reasons why there are 2 dates per row they represent different but comparable activities)
I have a table "Assessment tracker" with the following structure
Name           Type
Candidate      short text
Unit              short text
EV1 Date        Date
EV2 Date        Date
My Data:
Candidate Unit EV1Date    EV2 Date
TH1         10  07/05/2015 25/05/15
TH1         10  07/05/2015 07/06/15
I have a query "Candidate AC Dates" that compares the 2 dates EV1 and EV2 and outputs a 3rd column with the latest date. 
Query:
PARAMETERS [Candidate Name] Value;
SELECT [Assessment Tracker].Candidate, [Assessment Tracker].Unit, [Assessment Tracker].[EV1 Date], [Assessment Tracker].[EV2 Date], Max(MaxDate([Assessment Tracker]![EV1 Date],[Assessment Tracker]![EV2 Date])) AS Achdate
FROM UnitData INNER JOIN [Assessment Tracker] ON UnitData.Unit = [Assessment Tracker].Unit
[Code]....
Output: 
CandidateUnitEV1 DateEV2 DateAchdate
TH11007/05/2015        25/05/201525/05/2015
TH11007/05/2015        07/06/201507/06/2015
It does this by using a function shamelessly copied from the web somewhere...
Function Maxdate(ParamArray FieldArray() As Variant)
' Declare the two local variables.
Dim I As Integer
Dim currentVal As Date' Set the variable currentVal equal to the array of values.
currentVal = FieldArray(0)
' Cycle through each value from the row to find the largest.
 
[Code]....
This is working well (I think)
I then want to find the latest date for the 2 records i.e. the Max value for the Achdate.
Query:
SELECT [Candidate AC Dates].Candidate AS Expr1, [Candidate AC Dates].Unit AS Expr2, Max([Candidate AC Dates].Achdate) AS MaxOfAchdate
FROM [Candidate AC Dates]
GROUP BY [Candidate AC Dates].Candidate, [Candidate AC Dates].Unit
ORDER BY [Candidate AC Dates].Candidate, [Candidate AC Dates].Unit, Max([Candidate AC Dates].Achdate) DESC;
But this is returning
Candidate Unit MaxOfAchdate
TH1      1025/05/2015
I expect it to return
Candidate UnitMaxOfAchdate
TH1         10       07/06/2015
It looks to me like MAX is considering only the day value rather than the whole date. I suspect this is because it is considering the results of the function in the first query as a short text rather than a date field. (I've tried to force this through declaring the variables as dates but don't know where else to force this. (I am UK based hence the DD/MM/YYYY format) 
	View 14 Replies
    View Related
  
    
	
    	
    	Aug 11, 2015
        
        A query TaxType_Query produces the following results
TaxType; FromDate; ContactID, FullName
W2; 7/1/15; 1, Tom
1099; 4/1/15; 1,Tom
W2; 1/1/15; 1, Tom
W2; 1/1/10; 2, Dick
1099; 1/1/09; 3, Harry
I need the query to show only the rows with the maximum FromDate for each ContactID (result would be the 1st, 4th and 5th rows only).  I assume there is a quick SQL statement that will work better than Totals / Max criteria method.  If I set the FromDate criteria to Max the TaxType field is a problem as they have different values I cannot group by that field. 
	View 1 Replies
    View Related
  
    
	
    	
    	Apr 5, 2006
        
        I always have a problem getting this to work without a lot of effort and I know it should be easier than I make it out to be. Problem is say I have a bunch of records I need to summarize by month. Say Dec 05, Jan 06, Feb 06, etc. When I bring down the date col, I do something like:
Format([date],"mmm - yy") 
And do a totals query with a second col that returns say a count for each period. This works fine except that when I sort I get Dec 05, Feb 06, Jan 06, etc.
How can I do this with out having to create a third col to do the sorting stuff? Should I somehow wait until the data gets to the report to do the date format stuff???
:confused: :confused:
	View 1 Replies
    View Related
  
    
	
    	
    	Apr 25, 2006
        
        I have a huge table with transaction dates.  I need to slice and dice
this data (sum, %'s, etc), but group by FY.  Our fiscal year is from
7/1 thru 6/1.
For example:
1/8/2004 = FY 2004,
8/12/2004 = FY 2005,
2/3/2006 = FY 2006
THEN . . . .  I need to also isolate certain periods, for example July-
March for YTD (year-to-date) analysis and compare YTD of 2006 with that
of 2005.
What do you suggest?  Many thanks.
Mehran
	View 7 Replies
    View Related
  
    
	
    	
    	Dec 14, 2004
        
        I am needing help with how to set up the code to select different queries based on different conditions.
The database is to be set up so that I can pull studies at different time points based on if they are under long term, accelerated or stressed conditions. When this condition is selected there are only certain time points which are to be run, 
example..... 
Long term: 3,6,9,12,24,36,48 and 60 months.
Accelerated: 3,6,9 and 12 months.
As you can see I have the dates calculated for all of the weeks and months that the sample could be pulled at, Inventory Transactions Table. And I am able to generate throught the Pull Dates Form a list of only the records to be pulled under Long Term conditions. I would like to have the form set up so that when I choose the Accelerated condition that it would pull from another Query like the Pull Dates Long Term, but only have the Accelerated time points listed.
I am not sure if I need an If/Then statement and if so how do I set this up.
	View 6 Replies
    View Related
  
    
	
    	
    	Feb 6, 2014
        
        I have a query that I need to total by each month of the year. Field names and types are as follows
ID (PK)
Month (Date/Time)
PoliceResponse (1 or 0)
TerminalCheckTrue (1 or 0)
RampCheckTrue (1 or 0)
AOACheckTrue (1 or 0)
TotalTerminalRampAOA (TerminalCheckTrue + RampCheckTrue + AOACheckTrue)
TotalChecks (PoliceResponse+TerminalCheckTrue + RampCheckTrue + AOACheckTrue)
Now, I need to just get the total of each of these fields per month for the entire year. So it would look like
Jan, MonthlyPoliceResponse, MonthlyTerminalChecks, etc...
Feb, MonthlyPoliceResponse, MonthlyTerminalChecks, etc...
Mar, MonthlyPoliceResponse, MonthlyTerminalChecks, etc...
Below is a sample from the query. I guess Im just not sure where to start since there are multiple months the same value, but i need them to total up..
Code:
SELECT DISTINCTROW tblBlotter.ID, Format$([tblBlotter].[EntryDate],'mmmm yyyy') AS [Month], Sum(IIf([CKPoliceResponse],1,0)) AS PoliceResponseTrue, Sum(IIf([CKTerminalCheck],1,0)) AS TerminalCheckTrue, Sum(IIf([CKRampCheck],1,0)) AS RampCheckTrue, Sum(IIf([CKAOACheck],1,0)) AS AOACheckTrue, ([TerminalCheckTrue]+[RampCheckTrue]+[AOACheckTrue]) AS TotalTerminalRampAOA, ([PoliceResponseTrue]+[TerminalCheckTrue]+[RampCheckTrue]+[AOACheckTrue]) AS TotalChecks
FROM tblBlotter
GROUP BY tblBlotter.ID, Format$([tblBlotter].[EntryDate],'mmmm yyyy'), Year([tblBlotter].[EntryDate])*12+DatePart('m',[tblBlotter].[EntryDate])-1, Year([tblBlotter].[EntryTime])*12+DatePart('m',[tblBlotter].[EntryTime])-1;
	View 14 Replies
    View Related
  
    
	
    	
    	May 15, 2014
        
        I have a date of service [DOS] and a date of birth [Birth Date] 
I'm trying to calculate the age at the last day of the date of service year not the current year.
Example:
[Birth Date] = 6/25/1993
[DOS] = 10/18/2013
Age at the last day of the date of service year (12/31/2013) = 20
How to do this.  I tried 
Code:
DateDiff("yyyy",[BIRTH DATE],[DOS])+Int(Format([DOS],"mmdd")<Format([BIRTH DATE],"mmdd"))
 but this does not work correctly.
	View 8 Replies
    View Related
  
    
	
    	
    	Aug 28, 2014
        
        How can I select the first record of each year working with a table like this:
Code:
ID, value, date
0, 30, 01/01/2000
1, 40, 03/02/2000
2, 20, 10/03/2000
3, 10, 02/05/2001
4, 20, 09/08/2001
5, 10, 01/02/2001
I'd like to get this result from my Query:
Code:
30, 01/01/2000
10, 01/02/2001
	View 2 Replies
    View Related