× 說心事 政治時事 生活 運動 汽車 機車 自行車 相機 科技 理財 旅遊美食 娛樂 健康 美麗時尚 人際關係 文學故事 關於《思書》
吃喝玩樂 關於《思書》

Rails 的 unscope

紅寶鐵軌客
來關注...
關注:紅寶鐵軌客
關注有什麼好處?:當作者有新文章發佈時,「思書日報」就會匯總自動通知您,讓您更容易與作者互動。
x
紅寶鐵軌客
Rails 使用中,折磨中,享受中......
Victorian vintage round cut ruby engagement ring in 14k yellow gold 7mm center vs g h 984
    很久以前就是個「寫程式的」,其實,什麼程式都不熟⋯⋯
     
    就,這會一點點,那會一點點⋯⋯
作者最新發佈的文章:
  • Rails 如何檢查 URL 是否存在?
  • Rails 為什麼要使用 escape_javascript?
  • Rails 使用 Javascript Ajax 很簡單
作者最近參與的討論:
  • Rails 常見資安陷阱與解決方法
現在就加入《思書》,你就可以關注本作者了!
《思書》是一個每個人的寫作與論壇平台,特有的隱私管理,讓你寫作不再受限,討論更深入真實,而且免費。 趕快來試試!
還未加入《思書》? 現在就登錄! 已經加入《思書》── 登入
Rails 使用中,折磨中,享受中......
2017/04/29
42   0  

UnScope 用的人應該不多,我能不用也不用,但是,總有用到時,要配合它,一開時寫SQL時,最好就是能知道他的限制。

UnScope 只能用在Hash mode,不能用在 SQL 的 Where 字串內,有點可惜...   

在 SQL 的 Hash,正常

irb> @blogs = Blog.where(block: 0).to_sql

=> "SELECT \"blogs\".* FROM \"blogs\" WHERE \"blogs\".\"block\" = 0  ORDER BY \"blogs\".\"created_at\" DESC"

irb> @blogs = Blog.where(block: 0).unscope(where: :block).to_sql

=> "SELECT \"blogs\".* FROM \"blogs\"  ORDER BY \"blogs\".\"created_at\" DESC"

在 SQL 的字串,不能動作

irb> @blogs = Blog.where("block=0").to_sql

=> "SELECT \"blogs\".* FROM \"blogs\" WHERE (block=0)  ORDER BY \"blogs\".\"created_at\" DESC"

irb> @blogs = Blog.where("block=0").unscope(where: :block).to_sql

=> "SELECT \"blogs\".* FROM \"blogs\" WHERE (block=0)  ORDER BY \"blogs\".\"created_at\" DESC"

在 SQL 的字串,全部 unscope 可行!

irb> @blogs = Blog.where("block=0").unscope(:where).to_sql

=> "SELECT \"blogs\".* FROM \"blogs\"  ORDER BY \"blogs\".\"created_at\" DESC"

rewhere 也一樣:

irb> @blogs = Blog.where("block=0").rewhere(spam_block: 1)

SELECT "blogs".* FROM "blogs" WHERE (block=0) AND "blogs"."block" = $1  ORDER BY blogs"."created_at" DESC  [["block", 1]]

 
解決的方法式混合兩種

irb> @blogs = Blog.where(block: 1).where("role_id <> 0").count

SELECT COUNT(*) FROM "blogs" WHERE "blogs"."block" = $1 AND (role_id <> 0)  [["block", 1]]

=> 3

irb> @blogs = Blog.where(block: 1).where("role_id <> 0").unscope(where: :block).count

SELECT COUNT(*) FROM "blogs" WHERE (role_id <> 0)

=> 634

irb> @pc_blogs = PcBlog.where(spam_block: 1).where("pc_role_id <> 0").unscope(where: :spam_block).where("spam_block_editor_id is not null").count

SELECT COUNT(*) FROM "pc_blogs" WHERE (pc_role_id <> 0) AND (spam_block_editor_id is not null)

=> 25

irb> @pc_blogs = PcBlog.where(spam_block: 1).where("pc_role_id <> 0").unscope(where: :spam_block).where("spam_block <>0").count

SELECT COUNT(*) FROM "pc_blogs" WHERE (pc_role_id <> 0) AND (spam_block <>0)

=> 19
關於作者
很久以前就是個「寫程式的」,其實,什麼程式都不熟⋯⋯
 
就,這會一點點,那會一點點⋯⋯


標籤: rails unscope x 1 rails x 27

分享:


參與討論!
x
現在就加入《思書》,馬上參與討論!
《思書》是一個每個人的寫作與論壇平台,特有的隱私管理,用筆名來區隔你討論內容,讓你的討論更深入,而且免費。 趕快來試試!
還未加入《思書》? 現在就登錄! 已經加入《思書》── 登入