【问题标题】:sinatra +Datamapper + mysqlsinatra +Datamapper + mysql
【发布时间】:2015-05-06 15:29:01
【问题描述】:

我在 MySQL 中使用 Sinatra 和 DataMapper,但在查询数据库时遇到问题。

我的 models.rb 如下:

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")

这些项目被插入到数据库中,但是当我查询数据库时总是返回 nil 值,例如:

(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")

有谁知道我做错了什么,或者有关于寻找什么来解决问题的建议?

【问题讨论】:

  • 第一个代码 sn-p 是正确的,并在数据库中创建了两个完全正常的行,id-s 为 1 和 2。魔鬼在于缺少的细节:你如何到达 (rdb: 1) 提示?

标签: mysql ruby sinatra datamapper


【解决方案1】:

将这两行添加到models.rb:

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

(通知.adapter,而不是.adapt。)它会打印

[#, #]

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

【讨论】:

    猜你喜欢
    • 2023-03-14
    • 1970-01-01
    • 1970-01-01
    • 2015-02-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-11-10
    相关资源
    最近更新 更多