首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sinatra +Datamapper + mysql

sinatra +Datamapper + mysql
EN

Stack Overflow用户
提问于 2015-05-06 23:29:01
回答 1查看 448关注 0票数 1

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

我的models.rb如下:

代码语言:javascript
复制
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")

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

代码语言:javascript
复制
(rdb:1) @items =Item.all
[#<Item @id=nil @item=nil>, #<Item @id=nil @item=nil>]

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

代码语言:javascript
复制
(rdb:1) @items.count
2

我尝试直接进行查询,得到相同的结果:

代码语言:javascript
复制
adapter = DataMapper.repository(:default).adapt
adapter.select("SELECT * FROM items")

有没有人知道我做错了什么,或者对如何解决问题有什么建议?

EN

回答 1

Stack Overflow用户

发布于 2016-02-21 14:28:45

将以下两行添加到models.rb:

代码语言:javascript
复制
adapter = DataMapper.repository(:default).adapter
print adapter.select("SELECT * FROM items")

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

#、#

一切正常(ruby 2.1.7p400 (2015.08-18Revision 51632))。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30081188

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档