亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

ActiveRecord OR查詢

ActiveRecord OR查詢

慕無忌1623718 2019-08-26 17:52:04
ActiveRecord OR查詢你如何在Rails 3 ActiveRecord中進行OR查詢。我找到的所有示例都只有AND查詢。編輯:自Rails 5以來可以使用OR方法。請參閱ActiveRecord :: QueryMethods
查看完整描述

3 回答

?
繁花如伊

TA貢獻2012條經驗 獲得超12個贊

使用ARel


t = Post.arel_table


results = Post.where(

  t[:author].eq("Someone").

  or(t[:title].matches("%something%"))

)

結果SQL:


ree-1.8.7-2010.02 > puts Post.where(t[:author].eq("Someone").or(t[:title].matches("%something%"))).to_sql

SELECT     "posts".* FROM       "posts"  WHERE     (("posts"."author" = 'Someone' OR "posts"."title" LIKE '%something%'))


查看完整回答
反對 回復 2019-08-26
?
HUWWW

TA貢獻1874條經驗 獲得超12個贊

如果要對一列的值使用OR運算符,可以將數組傳遞給.where,ActiveRecord將使用IN(value,other_value)

Model.where(:column => ["value", "other_value"]

輸出:

SELECT `table_name`.* FROM `table_name` WHERE `table_name`.`column` IN ('value', 'other_value')

這應該相當于OR單個列


查看完整回答
反對 回復 2019-08-26
?
紅顏莎娜

TA貢獻1842條經驗 獲得超13個贊

在Rails 3中,它應該是

Model.where("column = ? or other_column = ?", value, other_value)

這還包括原始sql但我不認為在ActiveRecord中有一種方法可以進行OR操作。你的問題不是一個菜鳥問題。


查看完整回答
反對 回復 2019-08-26
  • 3 回答
  • 0 關注
  • 658 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號