sub query issue with active record.

i can manage the MySQL queries into active record.but in some cases basically with sub-queries.i didn’t get the correct output.

here when i trying to change the MySQL queries into active-record.

MySQL Query

select count() from ( SELECT transactions.loyalty_id FROM transactions JOIN loyalties ON (transactions.loyalty_id = loyalties.id) where loyalties.created_at > ‘2011-11-02’ GROUP BY transactions.loyalty_id HAVING COUNT()>1 ) as t

Here just i tried to convert into corresponding active record queries. But i didn’t get the correct output.

Transaction.count(:loyalty_id) , :joins=> [“JOIN loyalties ON (transactions.loyalty_id = loyalties.id)” ] , :conditions => ["loyalties.created_at > ? ",cdate], :group=> [“transactions.loyalty_id”], :having=> ["count(*) > 1 "] )

How to change that issue?

Hi,
   Modify your query to

   loyalties = Transaction.count(:loyalty_id , :joins=> :loyalties,
:conditions => ["loyalties.created_at > ? ",cdate], :group=>
["transactions.loyalty_id"], :having=> ["count(*) > 1 "]

   loyalties contain OrderedHash. Now do loyalties.count to get actual
count of filtered loyalties and that matches with your raw sql output.