method
references_eager_loaded_tables?

v4.0.2 -
Show latest stable
-
0 notes -
Class: ActiveRecord::Relation
- 1.0.0
- 1.1.6
- 1.2.6
- 2.0.3
- 2.1.0
- 2.2.1
- 2.3.8
- 3.0.0 (0)
- 3.0.9 (0)
- 3.1.0 (0)
- 3.2.1 (0)
- 3.2.8 (0)
- 3.2.13 (0)
- 4.0.2 (0)
- 4.1.8 (0)
- 4.2.1 (0)
- 4.2.7 (0)
- 4.2.9 (0)
- 5.0.0.1 (0)
- 5.1.7 (0)
- 5.2.3 (0)
- 6.0.0 (0)
- 6.1.3.1 (0)
- 6.1.7.7 (0)
- 7.0.0 (0)
- 7.1.3.2 (0)
- 7.1.3.4 (0)
- What's this?
references_eager_loaded_tables?()
private
Hide source
# File activerecord/lib/active_record/relation.rb, line 604 def references_eager_loaded_tables? joined_tables = arel.join_sources.map do |join| if join.is_a?(Arel::Nodes::StringJoin) tables_in_string(join.left) else [join.left.table_name, join.left.table_alias] end end joined_tables += [table.name, table.table_alias] # always convert table names to downcase as in Oracle quoted table names are in uppercase joined_tables = joined_tables.flatten.compact.map { |t| t.downcase }.uniq string_tables = tables_in_string(to_sql) if (references_values - joined_tables).any? true elsif !ActiveRecord::Base.disable_implicit_join_references && (string_tables - joined_tables).any? ActiveSupport::Deprecation.warn( "It looks like you are eager loading table(s) (one of: #{string_tables.join(', ')}) " "that are referenced in a string SQL snippet. For example: \n" "\n" " Post.includes(:comments).where(\"comments.title = 'foo'\")\n" "\n" "Currently, Active Record recognizes the table in the string, and knows to JOIN the " "comments table to the query, rather than loading comments in a separate query. " "However, doing this without writing a full-blown SQL parser is inherently flawed. " "Since we don't want to write an SQL parser, we are removing this functionality. " "From now on, you must explicitly tell Active Record when you are referencing a table " "from a string:\n" "\n" " Post.includes(:comments).where(\"comments.title = 'foo'\").references(:comments)\n" "\n" "If you don't rely on implicit join references you can disable the feature entirely " "by setting `config.active_record.disable_implicit_join_references = true`." ) true else false end end