aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--activerecord/CHANGELOG2
-rw-r--r--activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb1
-rw-r--r--activerecord/test/fixtures/db_definitions/sqlserver.drop.sql1
-rw-r--r--activerecord/test/fixtures/db_definitions/sqlserver.sql8
-rw-r--r--activerecord/test/table_name_test_sqlserver.rb23
5 files changed, 35 insertions, 0 deletions
diff --git a/activerecord/CHANGELOG b/activerecord/CHANGELOG
index 513179931a..0291d96a72 100644
--- a/activerecord/CHANGELOG
+++ b/activerecord/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*
+* SQLServer: handle [quoted] table names. #6635 [rrich]
+
* acts_as_nested_set works with single-table inheritance. #6030 [Josh Susser]
* PostgreSQL: use a subselect to correctly perform eager finds with :limit and :order. #4668 [eventualbuddha]
diff --git a/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb b/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb
index 3ecf26f530..b234239781 100644
--- a/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb
@@ -257,6 +257,7 @@ module ActiveRecord
return [] if table_name.blank?
table_name = table_name.to_s if table_name.is_a?(Symbol)
table_name = table_name.split('.')[-1] unless table_name.nil?
+ table_name = table_name.gsub(/[\[\]]/, '')
sql = %Q{
SELECT
cols.COLUMN_NAME as ColName,
diff --git a/activerecord/test/fixtures/db_definitions/sqlserver.drop.sql b/activerecord/test/fixtures/db_definitions/sqlserver.drop.sql
index b157d7c0a7..e8327f0826 100644
--- a/activerecord/test/fixtures/db_definitions/sqlserver.drop.sql
+++ b/activerecord/test/fixtures/db_definitions/sqlserver.drop.sql
@@ -30,3 +30,4 @@ DROP TABLE fk_test_has_pk;
DROP TABLE keyboards;
DROP TABLE legacy_things;
DROP TABLE numeric_data;
+DROP TABLE [order];
diff --git a/activerecord/test/fixtures/db_definitions/sqlserver.sql b/activerecord/test/fixtures/db_definitions/sqlserver.sql
index 7b6f1d7afd..50e1938d0a 100644
--- a/activerecord/test/fixtures/db_definitions/sqlserver.sql
+++ b/activerecord/test/fixtures/db_definitions/sqlserver.sql
@@ -228,3 +228,11 @@ CREATE TABLE numeric_data (
my_house_population decimal(2),
decimal_number_with_default decimal(3,2) DEFAULT 2.78
);
+
+CREATE TABLE [order] (
+ id int NOT NULL IDENTITY(1, 1) PRIMARY KEY,
+ color varchar(255),
+ fruit_size varchar(255),
+ texture varchar(255),
+ flavor varchar(255)
+);
diff --git a/activerecord/test/table_name_test_sqlserver.rb b/activerecord/test/table_name_test_sqlserver.rb
new file mode 100644
index 0000000000..c2d1711599
--- /dev/null
+++ b/activerecord/test/table_name_test_sqlserver.rb
@@ -0,0 +1,23 @@
+require 'abstract_unit'
+require "#{File.dirname(__FILE__)}/../lib/active_record/schema"
+
+if ActiveRecord::Base.connection.supports_migrations?
+ class Order < ActiveRecord::Base
+ self.table_name = '[order]'
+ end
+
+ class TableNameTest < Test::Unit::TestCase
+ self.use_transactional_fixtures = false
+
+ # Ensures Model.columns works when using SQLServer escape characters.
+ # Enables legacy schemas using SQL reserved words as table names.
+ # Should work with table names with spaces as well ('table name').
+ def test_escaped_table_name
+ assert_nothing_raised do
+ ActiveRecord::Base.connection.select_all 'SELECT * FROM [order]'
+ end
+ assert_equal '[order]', Order.table_name
+ assert_equal 5, Order.columns.length
+ end
+ end
+end