ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

rails 使用default_scope遇到的问题以及解决方案

2022-05-13 13:34:12  阅读:195  来源: 互联网

标签:unscope default posts rails scope Post where


1.使用default_scope

class Post < ActiveRecord::Base
  default_scope { where(published: true) }
end

2.1.1 :001 > Post.all
  Post Load (0.2ms)  SELECT "posts".* FROM "posts"  WHERE "posts"."published" = 1

2.使用default_scope需要小心的问题

 一、

2.1.1 :004 > Post.new
 => #<Post id: nil, title: nil, published: true, created_at: nil, updated_at: nil> 

 

二、

class Post < ActiveRecord::Base
  default_scope { where(published: true) }
  belongs_to :user
end 

class User < ActiveRecord::Base
  has_many :posts
end



2.1.1 :001 > User.first.posts
  Post Load (0.3ms)  SELECT "posts".* FROM "posts"  WHERE "posts"."published" = 't' AND "posts"."user_id" = ?  [["user_id", 1]]

三、使用假删除的时候,要注意unscoped的使用,unscope 会取消所有的scope, 包括deleted_at

3. 取消default scope   unscoped的使用

 

class User < ActiveRecord::Base
  default_scope { where tester: false }
  scope :testers, -> { unscope(:where).where tester: true }
  scope :with_testers, -> { unscope(:where).where tester: [true, false] }
  # ...
end

eg:

Foo.unscope(where: :bar)
or

scope :not_default, -> { unscope(where: :bar) }

Foo.not_default

It is currently possible to unscope stuff like: :where,:select, :group, :order, :lock, :limit, :offset, :joins, :includes, :from, :readonly, :having.

But still please avoid using of default_scope if you can. It's for your own good.

参考链接:

     https://stackoverflow.com/questions/1834159/overriding-a-rails-default-scope

          https://www.thinbug.com/q/25087336

 

 

标签:unscope,default,posts,rails,scope,Post,where
来源: https://www.cnblogs.com/hello-ruby/p/16266353.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有