In Rails 3, how do i select rows based on unique column values, i need to get all the columns for eg:
SELECT COUNT(DISTINCT date) FROM records
This only returns date column, but i want all the columns (name, date , age , created_at) columns not just the date.
Thanks for your help
The issue here is that, by definition, there may be multiple records with the same date. It requires logic in the user space to determine which of the multiple records with the unique date to use. Here’s some code to get those rows:
If what you’re really after is uniqueness among multiple columns, list all the relevant columns in the distinct query:
The fact that you are using distinct means that each “row” returned actually represents n rows, so the DB doesn’t know which of the n rows to pull the remaining columns from. That’s why it only returns the columns used in distinct. It can do no other…