unscopeはscope系以外の条件も外す 953 views Post @wakairo 06 Feb, 2023 01:42 +00:00 Last edited 06 Feb, 2023 02:03 +00:00 RailsのActive Recordには、scopeやdefault_scopeという機能があり、SQLクエリの条件を指定してあらかじめ付けておくことが可能です。 unscopeやunscopedは、これらのscope系で付けた条件を外すことが出来ます。 ただ、注意点として、scope系以外で付けた条件も外してしまいます。 以下に例を示します。 irb(main):001:0> puts User.where(id: 1).all.to_sql SELECT "users".* FROM "users" WHERE "users"."id" = 1 => nil irb(main):002:0> puts User.where(id: 1).unscope(:where).all.to_sql SELECT "users".* FROM "users" => nil irb(main):003:0> puts User.where(id: 1).unscoped.all.to_sql SELECT "users".* FROM "users" => nil unscopeやunscopedが、直前のwhere句で指定した条件を外していることが確認できます。 確認した環境 Rails 7.0.4 参考 Railsガイド:Active Record クエリインターフェイス:9 条件を上書きする
@wakairo 06 Feb, 2023 01:42 +00:00 Last edited 06 Feb, 2023 02:03 +00:00 RailsのActive Recordには、scopeやdefault_scopeという機能があり、SQLクエリの条件を指定してあらかじめ付けておくことが可能です。 unscopeやunscopedは、これらのscope系で付けた条件を外すことが出来ます。 ただ、注意点として、scope系以外で付けた条件も外してしまいます。 以下に例を示します。 irb(main):001:0> puts User.where(id: 1).all.to_sql SELECT "users".* FROM "users" WHERE "users"."id" = 1 => nil irb(main):002:0> puts User.where(id: 1).unscope(:where).all.to_sql SELECT "users".* FROM "users" => nil irb(main):003:0> puts User.where(id: 1).unscoped.all.to_sql SELECT "users".* FROM "users" => nil unscopeやunscopedが、直前のwhere句で指定した条件を外していることが確認できます。 確認した環境 Rails 7.0.4 参考 Railsガイド:Active Record クエリインターフェイス:9 条件を上書きする
RailsのActive Recordには、
scope
やdefault_scope
という機能があり、SQLクエリの条件を指定してあらかじめ付けておくことが可能です。unscope
やunscoped
は、これらのscope系で付けた条件を外すことが出来ます。ただ、注意点として、scope系以外で付けた条件も外してしまいます。
以下に例を示します。
unscope
やunscoped
が、直前のwhere
句で指定した条件を外していることが確認できます。確認した環境
参考