aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2011-03-21 11:19:14 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2011-03-21 11:20:45 -0700
commitea8fcfb729c0bca528d2e8522585cd6d0e98ebc7 (patch)
tree4128acc316c3965c13e6f18b3a45bf0888b0f3a6 /activerecord/lib
parent96b9fc44000e5f40ba463ff0e893db8c4fd33b85 (diff)
downloadrails-ea8fcfb729c0bca528d2e8522585cd6d0e98ebc7.tar.gz
rails-ea8fcfb729c0bca528d2e8522585cd6d0e98ebc7.tar.bz2
rails-ea8fcfb729c0bca528d2e8522585cd6d0e98ebc7.zip
schemas set by set_table_name are respected by the mysql adapter. [#5322 state:resolved]
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/connection_adapters/mysql_adapter.rb18
1 files changed, 16 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb b/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
index 368c5b2023..e1186209d3 100644
--- a/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
@@ -504,14 +504,28 @@ module ActiveRecord
show_variable 'collation_database'
end
- def tables(name = nil) #:nodoc:
+ def tables(name = nil, database = nil) #:nodoc:
tables = []
- result = execute("SHOW TABLES", name)
+ result = execute(["SHOW TABLES", database].compact.join(' IN '), name)
result.each { |field| tables << field[0] }
result.free
tables
end
+ def table_exists?(name)
+ return true if super
+
+ name = name.to_s
+ schema, table = name.split('.', 2)
+
+ unless table # A table was provided without a schema
+ table = schema
+ schema = nil
+ end
+
+ tables(nil, schema).include? table
+ end
+
def drop_table(table_name, options = {})
super(table_name, options)
end