我可以将两个连接资源连接在一起吗?
我已经实现它的方式,它不会出现。我可以将两个连接资源连接在一起吗?
在data_mapper方面 - 我有一个连接资源条目,即连接驱动程序,团队和季节
我有加入田径赛季
联接资源一场比赛,我有一个连接入口联接资源配售和种族。
当我尝试做一些像“给我所有的比赛,一个特定条目已经参加了与类似
@entry_a.races.all
我得到这个错误
DataObjects::SyntaxError: no such column: INNER (code: 1, sql state: , query: SELECT "races"."track_id", "races"."season _id", "races"."race_no" FROM "races" INNER JOIN "placings" ON INNER JOIN "entries" ON "placings"."entry_team_id" = "ent ries"."team_id" AND "placings"."entry_driver_id" = "entries"."driver_id" WHERE ("placings"."entry_team_id" = 'FER' AND " placings"."entry_driver_id" = 'MAS') GROUP BY "races"."track_id", "races"."season_id", "races"."race_no" ORDER BY "races "."track_id", "races"."season_id", uri: sqlite3:C/devProjects/formula1../spec/resources/test.db?scheme=sqlite3&user=&pas sword=&host=C&port=&query=&fragment=&adapter=sqlite3&path=/devProjects/formula1../spec/resources/test.db)
它很容易的看看这里发生了什么,用.all方法包装的查询不会期望加入连接
我设法通过编写一些自定义sql来解决这个问题虽然不理想,它确实完成了这项工作。它似乎并不是红宝石般的方式。也许我的数据库架构很糟糕?
这里是我的模型(关于代码转储抱歉。我已经得到了由家伙那么,谁决定downvote我烧了,因为我还没有完整引述代码)
require "rubygems"
require "sqlite3"
require "data_mapper"
require "bigdecimal"
#note that Dir.pwd refers to the location of the file that calls
if ENV["run_mode"] == "prod"
DataMapper::setup(:default, "sqlite3://#{Dir.pwd}/data/prod.db")
else
DataMapper::setup(:default, "sqlite3://#{Dir.pwd}../spec/resources/test.db")
end
class Entry
include DataMapper::Resource
belongs_to :team, :key => true
belongs_to :driver, :key => true
belongs_to :season, :key => true
has n, :placings
has n, :races, :through => :placings
def find_races
return repository.adapter.select('SELECT races.track_id, races.season_id, races.race_no FROM races INNER JOIN placings ON races.track_id = placings.race_track_id INNER JOIN entries ON placings.entry_driver_id = entries.driver_id WHERE (entries.team_id = ? AND entries.driver_id = ?)', self[:team_id], self[:driver_id])
end
end
class Track
include DataMapper::Resource
property :id, String, :key => true
has n, :races
end
class Race
include DataMapper::Resource
property :race_no, Integer
belongs_to :track, :key => true
belongs_to :season, :key => true
has n, :placings
has n, :entries, :through => :placings
end
class Placing
include DataMapper::Resource
property :id, Serial #put this in because dm was complaining that foreign keys from entry object were not unique
belongs_to :race
belongs_to :entry
end
class Season
include DataMapper::Resource
property :id, Integer, :key => true
has n, :races
has n, :entries
end
class Driver
include DataMapper::Resource
property :id, String, :key => true
property :team, String
property :ptd, Integer
property :races, Integer
property :grid, Object
property :race, Object
property :cumulativePoints, Object #the number of points accumulated at a particular point in the season
property :hcScore, Integer
property :domScore, Integer
property :nation, String
property :wins, Integer
property :podiums, Integer
has n, :entries
has n, :teams, :through => :entries
end
class Team
include DataMapper::Resource
property :id, String, :key => true
property :name, String
property :ptd, Integer
property :domScore, Integer
property :nation, String
has n, :entries
has n, :drivers, :through => :entries
def initialize(team_id)
self[:id] = team_id
self.save!
end
def add_driver(driver_id)
@driver = Driver.create(:id => driver_id)
Entry.create(:driver => (Driver.get driver_id), :team => self, :season => Season.last)
return @driver
end
end
class Nation
include DataMapper::Resource
property :id, String, :key => true
property :ptd, Integer
# could possibly have the drivers, teams and engines here as well
end
if ENV["run_mode"] == "test"
DataMapper.finalize.auto_migrate!
else
DataMapper.finalize.auto_upgrade!
end
一些测试后,我想你看到的错误与组合键有关;尝试更改Race的单个串行密钥。我认为这是DM中的一个错误。
我不得不尝试做Driver.first.races
复合主键时同样的错误出现,但只有一个序列键,它的工作:
$KCODE='u'
require 'rubygems'
require 'dm-core'
require 'dm-migrations'
DataMapper::Logger.new($stdout, :debug)
DataMapper.setup(:default, "sqlite::memory:")
class Entry
include DataMapper::Resource
#property :id, Serial # maybe also here? Although everything seems to work without
property :grid, Integer
property :position, Integer
belongs_to :driver, :key => true
belongs_to :race, :key => true
end
class Driver
include DataMapper::Resource
property :name, String, :key => true
has n, :entries
has n, :races, :through => :entries
def podiums; entries(:position => (1..3)) end
def wins; entries(:position => 1) end
end
class Race
include DataMapper::Resource
property :id, Serial
belongs_to :track
belongs_to :season
has n, :entries
has n, :drivers, :through => :entries
end
class Season
include DataMapper::Resource
property :year, Integer, :key => true
has n, :races
end
class Track
include DataMapper::Resource
property :name, String, :key => true
has n, :races
end
DataMapper.finalize.auto_migrate!
Entry.create(
:driver => Driver.new(:name => "Kimi Räikkönen"),
:grid => 7, :position => 1,
:race => Race.new(
:track => Track.new(:name => "Albert Park"),
:season => Season.new(:year => 2013)))
感谢您寻找到它和neatening了我的代码的其他部分!而最新的例子:)去冰人:) – JoeyC 2013-03-21 08:08:57