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

Ask A Question

Stats

  • Questions 304k
  • Answers 304k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer You want to use a map: class Network { public:… May 13, 2026 at 8:50 pm
  • Editorial Team
    Editorial Team added an answer if ('createRange' in document && 'getSelection' in window) { //… May 13, 2026 at 8:50 pm
  • Editorial Team
    Editorial Team added an answer This information is lost. You should single-step in the code… May 13, 2026 at 8:50 pm

Related Questions

Expanding on recent_posts_on_self below, I want to add an all_recent_posts_on_self method but I'm not
I have 3 model, User, Post, Comment with definition like below class Post <
I am a Ruby on Rails newbie and had a question about the view
I have a fairly standard blog app with the usual post and comments controller/models
I'm just getting up to speed with asp.net mvc and I'm wondering how one

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

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.