So I have 3 rows in a table
╔══════════════════════════════════════════════════════╗
║ Id TenancyId StartDate EndDate Other Data ║
╠══════════════════════════════════════════════════════╣
║ 31 5198 2016-05-02 NULL ║
║ 30 5198 2016-01-08 2016-04-07 ║
║ 29 5198 2016-04-08 2016-05-01 ║
╚══════════════════════════════════════════════════════╝
I am using the query :-
SELECT Id, max(StartDate), FrequencyNumber, FrequencyLetter, Arrears FROM PaymentSchedule WHERE TenancyId=5198 GROUP BY TenancyId
I was expecting when I used the max it would return all the details from the row with the maximum date however I am getting this info back in my query...
Array ( [Id] => 30 [max(StartDate)] => 2016-05-02
so it is picking out the maximum start date but returning the wrong row (ID) I have indexed the columns.
Any help would be much appreciated