希望有人可以通过一个例子或一些建议的阅读来阐明这个问题。我想知道在类层次结构对等之后为表建模的最佳设计方法是什么。这可以通过一个例子来最好地描述:
abstract class Card{
private $_name = '';
private $_text = '';
}
class MtgCard extends Card{
private $_manaCost = '';
private $_power = 0;
private $_toughness = 0;
private $_loyalty = 0;
}
class PokemonCard extends Card{
private $_energyType = '';
private $_hp = 0;
private $_retreatCost = 0;
}
现在,当对表进行建模以与此类层次结构同步时,我使用了非常相似的东西:
TABLE Card
id INT, AUTO_INCREMENT, PK
name VARCHAR(255)
text TEXT
TABLE MtgCard
id INT, AUTO_INCREMENT, PK
card_id INT, FK(card.id)
manacost VARCHAR(32)
power INT
toughness INT
loyalty INT
TABLE PokemonCard
id INT, AUTO_INCREMENT, PK
card_id INT, FK(card.id)
hp INT
energytype ENUM(...)
retreatcost INT
我遇到的问题是试图弄清楚如何将每条Card
记录与相应表中包含其详细信息的记录相关联。具体来说,如何确定我应该查看哪个表。
我应该添加一VARCHAR
列来Card
保存关联表的名称吗?这是我和我的同龄人达成的唯一解决方案,但它似乎太“肮脏”了。保持设计的可扩展性是这里的关键,允许轻松添加新的子类。
如果有人可以提供一个示例或资源来显示镜像类/表层次结构的干净方式,那将不胜感激。