aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2007-09-17 06:15:58 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2007-09-17 06:15:58 +0000
commitbfb906a905a1e8774e438b10e8cf703a829b55dc (patch)
treea24612f8ed74de3dec4519649488b817839f7dd5 /activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb
parent30fb7b8c8bfc72ed3097352539544c07cbb38d0d (diff)
downloadrails-bfb906a905a1e8774e438b10e8cf703a829b55dc.tar.gz
rails-bfb906a905a1e8774e438b10e8cf703a829b55dc.tar.bz2
rails-bfb906a905a1e8774e438b10e8cf703a829b55dc.zip
Speed up and simplify query caching.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7498 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb')
-rw-r--r--activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb43
1 files changed, 18 insertions, 25 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb b/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb
index 57eefbf1d6..62d7e5364c 100644
--- a/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb
@@ -132,37 +132,18 @@ module ActiveRecord
catch_schema_changes { log(sql, name) { @connection.execute(sql) } }
end
- def update(sql, name = nil) #:nodoc:
- execute(sql, name)
+ def update_sql(sql, name = nil) #:nodoc:
+ super
@connection.changes
end
- def delete(sql, name = nil) #:nodoc:
+ def delete_sql(sql, name = nil) #:nodoc:
sql += " WHERE 1=1" unless sql =~ /WHERE/i
- execute(sql, name)
- @connection.changes
+ super sql, name
end
- def insert(sql, name = nil, pk = nil, id_value = nil, sequence_name = nil) #:nodoc:
- execute(sql, name = nil)
- id_value || @connection.last_insert_row_id
- end
-
- def select_all(sql, name = nil) #:nodoc:
- execute(sql, name).map do |row|
- record = {}
- row.each_key do |key|
- if key.is_a?(String)
- record[key.sub(/^\w+\./, '')] = row[key]
- end
- end
- record
- end
- end
-
- def select_one(sql, name = nil) #:nodoc:
- result = select_all(sql, name)
- result.nil? ? nil : result.first
+ def insert_sql(sql, name = nil, pk = nil, id_value = nil, sequence_name = nil) #:nodoc:
+ super || @connection.last_insert_row_id
end
def select_rows(sql, name = nil)
@@ -267,6 +248,18 @@ module ActiveRecord
protected
+ def select(sql, name = nil) #:nodoc:
+ execute(sql, name).map do |row|
+ record = {}
+ row.each_key do |key|
+ if key.is_a?(String)
+ record[key.sub(/^\w+\./, '')] = row[key]
+ end
+ end
+ record
+ end
+ end
+
def table_structure(table_name)
returning structure = execute("PRAGMA table_info(#{table_name})") do
raise(ActiveRecord::StatementInvalid, "Could not find table '#{table_name}'") if structure.empty?