aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-08-14 19:48:33 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-08-14 19:48:33 -0700
commite1155aa922a04e1cce60a660b4b779bfe3d7d7f5 (patch)
tree6171a44551b43f451c4a2e64b3f4179e4b147585
parent703326cdc2e6ad426c09cfbf7983f893552ac845 (diff)
downloadrails-e1155aa922a04e1cce60a660b4b779bfe3d7d7f5.tar.gz
rails-e1155aa922a04e1cce60a660b4b779bfe3d7d7f5.tar.bz2
rails-e1155aa922a04e1cce60a660b4b779bfe3d7d7f5.zip
update is working on the select manager
-rw-r--r--lib/arel/select_manager.rb9
-rw-r--r--lib/arel/update_manager.rb4
-rw-r--r--lib/arel/visitors/to_sql.rb2
-rw-r--r--spec/arel/select_manager_spec.rb48
-rw-r--r--spec/arel/update_manager_spec.rb8
5 files changed, 70 insertions, 1 deletions
diff --git a/lib/arel/select_manager.rb b/lib/arel/select_manager.rb
index 444ca8f716..7379596aba 100644
--- a/lib/arel/select_manager.rb
+++ b/lib/arel/select_manager.rb
@@ -27,6 +27,15 @@ module Arel
end
# FIXME: this method should go away
+ def update values
+ um = UpdateManager.new @engine
+ um.table values.first.first.relation
+ um.set values
+ um.wheres = @ctx.wheres
+ @engine.connection.execute um.to_sql
+ end
+
+ # FIXME: this method should go away
def insert values
im = InsertManager.new @engine
im.insert values
diff --git a/lib/arel/update_manager.rb b/lib/arel/update_manager.rb
index cc2f973842..f712103f98 100644
--- a/lib/arel/update_manager.rb
+++ b/lib/arel/update_manager.rb
@@ -12,6 +12,10 @@ module Arel
self
end
+ def wheres= exprs
+ @head.wheres = exprs
+ end
+
def where expr
@head.wheres << expr
self
diff --git a/lib/arel/visitors/to_sql.rb b/lib/arel/visitors/to_sql.rb
index 4c2a6a10e4..5536ba0267 100644
--- a/lib/arel/visitors/to_sql.rb
+++ b/lib/arel/visitors/to_sql.rb
@@ -16,7 +16,7 @@ module Arel
[
"UPDATE #{visit o.relation}",
("SET #{o.values.map { |column,value|
- "#{quote_column_name(column.name)} = #{quote visit value}"
+ "#{quote_column_name(column.name)} = #{value ? quote(visit(value)) : 'NULL'}"
}.join ', '}" unless o.values.empty?),
("WHERE #{o.wheres.map { |x| visit x }.join ' AND '}" unless o.wheres.empty?)
].compact.join ' '
diff --git a/spec/arel/select_manager_spec.rb b/spec/arel/select_manager_spec.rb
index 928db49c52..e456cabc16 100644
--- a/spec/arel/select_manager_spec.rb
+++ b/spec/arel/select_manager_spec.rb
@@ -1,7 +1,55 @@
require 'spec_helper'
module Arel
+ class EngineProxy
+ attr_reader :executed
+
+ def initialize engine
+ @engine = engine
+ @executed = []
+ end
+
+ def connection
+ self
+ end
+
+ def quote_table_name thing; @engine.connection.quote_table_name thing end
+ def quote_column_name thing; @engine.connection.quote_column_name thing end
+ def quote thing, column; @engine.connection.quote thing, column end
+
+ def execute sql
+ @executed << sql
+ end
+ end
+
describe 'select manager' do
+ describe 'update' do
+ it 'copies where clauses' do
+ engine = EngineProxy.new Table.engine
+ table = Table.new :users
+ manager = Arel::SelectManager.new engine
+ manager.where table[:id].eq 10
+ manager.from table
+ manager.update(table[:id] => 1)
+
+ engine.executed.last.should be_like %{
+ UPDATE "users" SET "id" = 1 WHERE "users"."id" = 10
+ }
+ end
+
+ it 'executes an update statement' do
+ engine = EngineProxy.new Table.engine
+ table = Table.new :users
+ manager = Arel::SelectManager.new engine
+ manager.from table
+ manager.update(table[:id] => 1)
+
+ engine.executed.last.should be_like %{
+ UPDATE "users" SET "id" = 1
+ }
+ end
+ end
+
describe 'project' do
it 'takes strings' do
table = Table.new :users
diff --git a/spec/arel/update_manager_spec.rb b/spec/arel/update_manager_spec.rb
index 97b497b377..9c3789193e 100644
--- a/spec/arel/update_manager_spec.rb
+++ b/spec/arel/update_manager_spec.rb
@@ -9,6 +9,14 @@ module Arel
end
describe 'set' do
+ it "updates with null" do
+ table = Table.new(:users)
+ um = Arel::UpdateManager.new Table.engine
+ um.table table
+ um.set [[table[:name], nil]]
+ um.to_sql.should be_like %{ UPDATE "users" SET "name" = NULL }
+ end
+
it 'takes a list of lists' do
table = Table.new(:users)
um = Arel::UpdateManager.new Table.engine