db.executeした際に配列が帰ってきた。カラム名でアクセス出来る方法がないか探したところ、 results_as_hash = trueにすれば、Hashで返ってくることがわかった。

SQLite3/Ruby FAQ

##I’d like the rows to be indexible by column name. >By default, each row from a query is returned as an Array of values. This means that you can only obtain values by their index. Sometimes, however, you would like to obtain values by their column name.

The first way to do this is to set the Database property “results_as_hash” to true. If you do this, then all rows will be returned as Hash objects, with the column names as the keys. (In this case, the “fields” property is unavailable on the row, although the “types” property remains.)


  db.results_as_hash = true
  db.execute( "select * from table" ) do |row|
    p row['column1']
    p row['column2']

The other way is to use Ara Howard’s ArrayFields module. Just require “arrayfields”, and all of your rows will be indexable by column name, even though they are still arrays!

  require 'arrayfields'

  db.execute( "select * from table" ) do |row|
    p row[0] == row['column1']
    p row[1] == row['column2']


require 'rubygems'
require 'sqlite3'

db = SQLite3::Database.new("development.sqlite3")
db.results_as_hash = true

sql = "select * from entries"

db.execute(sql) do |row|
	p row