sinatra +Datamapper + mysql



我正在使用sinatra和datamapper和mysql,当我查询数据库时会遇到问题。

我的模型.rb是folloging:

require 'sinatra'
require 'dm-core'
require 'dm-migrations/adapters/dm-mysql-adapter'
DataMapper::Logger.new("log/datamapper.log", :debug)
DataMapper.setup(:default, 'mysql://user:password@localhost/testdb')
class Item
  include DataMapper::Resource
  property :id,           Serial
  property :item,         String, :length => 50  
end
DataMapper.finalize
DataMapper.auto_upgrade!

Item.create(item:"item_one")
Item.create(item:"item_two")

项目插入数据库中,但是当我查询数据库总是返回零值时,示例:

(rdb:1) @items =Item.all
[#<Item @id=nil @item=nil>, #<Item @id=nil @item=nil>]

如果我查询项目的数量,我得到的预期结果:

(rdb:1) @items.count
2

我试图直接获得相同结果的查询:

adapter = DataMapper.repository(:default).adapt
adapter.select("SELECT * FROM items")

有人知道我在做错什么或对要解决问题的问题有建议吗?

将这两行添加到模型中。rb:

adapter = DataMapper.repository(:default).adapter
print adapter.select("SELECT * FROM items")

(注意.adapter,而不是.adapt。)它打印

[#&lt; struct ID = 1,item =" item_one">,#&lt; struct ID = 2,item =" item_two">]

一切都按预期工作(Ruby 2.1.7p400(2015-08-18修订51632))。

最新更新