我认为我的问题需要一个数据透视表,但我想在花费大量时间尝试实现之前要清楚。我还没有为任何项目使用数据透视表。
我有一个新项目,其中包含多个“套件”,其中包含常见的“部件”,在某些情况下,部件可以与另一个套件的部件互换。同样地,并非所有部件都彼此兼容。
我不希望创建一些噩梦般的SQL查询,而是希望基本上构建一个存储兼容性信息的表,以便交叉引用简单的SQL查询。
示例:
SELECT kitID FROM crossRefTable WHERE partA, partC and partE are true.
或者例如:
SELECT partID FROM crossRefTable WHERE partA and partE are true.
(是的,SQL查询仅仅是为了强调这一点)
我不确定“属于”和“ hasMany ”是否一定适用于此,或者如果是这样,将如何实施?
使用 MongoDB 在 PhalconPHP 中进行编码。
感谢您的意见和建议。
史蒂芬
答案 0 :(得分:0)
假设您有23个套件和512个不同的部件。如何定义套件1使用零件A,B和C,而套件2使用零件A,D,E和F?数据透视表是定义每个工具包及其部件之间关系的好方法。一旦你有了一个Kits表,一个Parts表和一个KitParts表,那么你可以将这三个表连在一起以便于查询。一旦加入成为你的第二天性,他们实际上很乐意与你合作。
就PhalconPHP而言,hasMany
和belongsTo
(note it has an s)与数据透视表相结合是一个很好的解决方案。在数据透视表中,您可以引用工具包的ID和部分ID。
我们假设用户当前正在查看所有套件的列表,并且他们点击了特定的套件,现在您想要显示所有部件包含的内容。您的示例几乎与Phalcon manual shows的情况完全相同。但就我个人的写作方式而言,我采取以下方式:
(注意:这都是未经测试的,我几个月内没有接触过phalcon)
//Use your BaseModel to take some of the weight off your Models.
//Nobody likes dirty Models, just ask Victoria's Secret. :p
//BaseModels are a good place to add your own methods,
//that way all models have access to them.
class BaseModel extends \Phalcon\Mvc\Model
{
}
class Kits extends Basemodel
{
public $id;
public $name;
public function initialize()
{
$this->hasMany('id', 'KitParts', 'kit_id', array(
'foreignKey' => array(
'message' => 'Kit cannot be deleted because it\'s used by KitParts'
)
));
}
}
//Pivot table
class KitParts extends BaseModel
{
public $id;
public $kit_id; //primary key used in Kits.id
public $part_id; //primary key used in Parts.id
$this->belongsTo('kit_id', 'Kits', 'id');
$this->belongsTo('part_id', 'Parts', 'id');
}
class Parts extends BaseModel
{
public $id;
public $name;
public function initialize()
{
$this->hasMany('id', 'KitParts', 'part_id', array(
'foreignKey' => array(
'message' => 'Part cannot be deleted because it\'s used by KitParts'
)
));
}
}
然后要显示特定套件的所有部件,请写下:
$kit = Kits::findFirst(123);//Find record with id = 123
foreach ($kit->kitParts as $kitPart)
{
echo htmlentities($kitPart->parts->name), "<br>\n";
}
您还可以向Kits类添加一个方法,以简化生活: (同样,这是未经测试的......如果出现问题,请参考documentation。)
//Add this as a method to the "Kits" class
public function getParts()
{
$results = array();
foreach ($this->kitParts as $kitPart)
{
$results[] = $kitPart->parts;
}
return $results;
}
然后你做:
$kit = Kits::findFirst(123);//Find record with id = 123
$parts = $kit->getParts();
if(count($parts) > 0)
{
echo "<strong>Parts</strong><br>\n";
foreach($parts as $part)
{
echo htmlentities($part->name),"<br>\n";
}
}else{
echo "No parts to show.<br>\n";
}