Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/ruby/22.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
西纳特拉+;数据映射器&x2B;mysql_Mysql_Ruby_Sinatra_Datamapper - Fatal编程技术网

西纳特拉+;数据映射器&x2B;mysql

西纳特拉+;数据映射器&x2B;mysql,mysql,ruby,sinatra,datamapper,Mysql,Ruby,Sinatra,Datamapper,我在MySQL中使用Sinatra和DataMapper,在查询数据库时遇到问题 My 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@l

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

My 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")
项目插入到数据库中,但当我查询de时,数据库始终返回零值,例如:

(rdb:1) @items =Item.all
[#<Item @id=nil @item=nil>, #<Item @id=nil @item=nil>]
我尝试直接进行查询,得到相同的结果:

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

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

将这两行添加到models.rb:

adapter = DataMapper.repository(:default).adapter
print adapter.select("SELECT * FROM items")
(注意,
.adapter
,而不是
.adapt
)它会打印

[#,#]


一切正常(ruby 2.1.7p400(2015-08-18修订版51632))。

第一个代码段是正确的,在数据库中创建了两个完全正常的行,id为-s 1和2。问题在于缺少的细节:如何到达(rdb:1)提示符?
adapter = DataMapper.repository(:default).adapter
print adapter.select("SELECT * FROM items")