diff options
author | Jeremy Kemper <jeremy@bitsweat.net> | 2007-09-17 06:15:58 +0000 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2007-09-17 06:15:58 +0000 |
commit | bfb906a905a1e8774e438b10e8cf703a829b55dc (patch) | |
tree | a24612f8ed74de3dec4519649488b817839f7dd5 /activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb | |
parent | 30fb7b8c8bfc72ed3097352539544c07cbb38d0d (diff) | |
download | rails-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.rb | 43 |
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? |