Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 537475
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 13, 20262026-05-13T09:55:51+00:00 2026-05-13T09:55:51+00:00

Posts has_many Comments I’m using searchlogic which will order by named scopes. So, I’d

  • 0

Posts has_many Comments

I’m using searchlogic which will order by named scopes. So, I’d like a named scope that orders by each post’s most recent comment.

named_scope :ascend_by_comment, :order => ...comments.created_at??...

I’m not sure how to do a :joins and get only the most recent comment and sort by its created_at field, all in a named_scope.

I’m using mysql, fyi.

EDIT:

This is the SQL query I’d be trying to emulate:

SELECT tickets.*, comments.created_at AS comment_created_at FROM tickets 
INNER JOIN 
(SELECT comments.ticket_id, MAX(comments.created_at) AS created_at 
  FROM comments group by ticket_id) comments 
ON tickets.id = comments.ticket_id ORDER BY comment_created_at DESC;
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-13T09:55:51+00:00Added an answer on May 13, 2026 at 9:55 am
    named_scope :ascend_by_comment,
      :joins => "LEFT JOIN comments ON comments.post_id = posts.id",
      :group => "id",
      :select => "posts.*, max(comments.created_at) AS comment_created_max",
      :order => "comment_created_max ASC"
    

    You can try to optimize it, but it should work and give you some hints how to do it.

    Edit:

    After you edited question and shown that you want inner join (no posts without comments?), you can of course change :joins => "..." with :joins => :comments.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I'm currently using: @user = User.find(params[:id]) @posts = @user.posts @comments = @user.comments To display
If I have something like this: class Post < ActiveRecord::Base has_many :comments, :as =>
I'm trying to write a route that captures the one-to-many relationship between posts and
I want to create a system for users to comment on posts where comments
I have a comment form (in comments/_form.html.erb) that I use in my other controllers
Hi guys I know that this is really bad idea but I want join
Update following initial comments The model has an object in it called 'Account', of
I am trying to wrap my head around this problem. I know views shouldn't
I'm getting this error: undefined method `post_comments_path' for #<#<Class:0x1052a6e98>:0x1052a4be8> Extracted source (around line #27):
I have a sqlite3 db in a rails app with the following schema ActiveRecord::Schema.define(:version

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.