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

  • SEARCH
  • Home
  • 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 8706931
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 13, 20262026-06-13T03:44:23+00:00 2026-06-13T03:44:23+00:00

Consider these scopes on an ActiveRecord model: scope :onsale, where(:sales_state => onsale) scope :outdated,

  • 0

Consider these scopes on an ActiveRecord model:

scope :onsale, where(:sales_state => "onsale")
scope :outdated, where(:sales_state => "outdated")
scope :onsale_or_outdated, where(" sales_state = 'onsale' OR sales_state = 'outdated' ")

Why is it that Rails knows to override :onsale with :outdated, but not :onsale with :onsale_or_outdated?

My use case:

I have a relation object with many scopes (let’s say it’s a saved search), and one of those is :onsale. I want to make another relation starting from that, but this time I want the sales_state to be either onsale or outdated.

If I use relation.onsale_or_outdated, the sales_state is not overridden, it just adds a new condition.

[...] WHERE "cars"."sales_state" = 'onsale' [...] AND (("cars"."sales_state" = 'onsale' OR "cars"."sales_state" = 'outdated'))

How can I use my ‘or’-ed condition in this context?

  • 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-06-13T03:44:24+00:00Added an answer on June 13, 2026 at 3:44 am

    If I use relation.onsale_or_outdated, the sales_state is not overridden, it just adds a new condition.

    That’s how scopes work. They append, not replace. If you have two mutually exclusive scopes, you need to use one or the other, not both. The special case is when you have a scope involves a single field in :symbol = <value> syntax. Rails is smart enough to allow one scope to cancel the other out. In your case, the onsale_or_updated scope is simply a string, Rails has no means to tell which fields are involved and so the scopes are chained.

    You should rewrite your scope to use fields/values instead of a blob of SQL, so Rails knows which fields are involved.

    scope :onsale_or_outdated, where(:sales_state => %w(onsale outdated))
    

    Alternatively, if you want to use only your onsale_or_outdated scope, you can unscope the relationship and reapply a scope:

    relation.unscoped.onsale_or_outdated
    

    Note that this will remove any previously applied scopes.

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

Sidebar

Related Questions

I ran across a compilation issue today that baffled me. Consider these two container
For example, consider the following code (in a model): scope :popular, where(views >= 250
Consider these simple, Reminder & event models: class Event < ActiveRecord::Base has_many :reminders end
Consider these two classes mapped to the same table. One is readonly via mutable=false.
Consider these 2 pieces of code (you can assume execeptionObj is of type Object
Consider these three mysql statements: select * from Users; select id, title, value from
Consider these pseudo models: class BaseProduct: quantity_available = Integer class Box(BaseProduct): items_in_box = Integer
Consider these several tables: tab1 ------- userid email address environment tab2 ------- ecode company
To give an idea of my requirement, consider these classes - class A {
Unfortunately, I have to deal with J2ME (which I consider ancient technology these days)

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.