有人可以帮助我理解外行表中的数据透视表吗?

时间:2016-06-22 03:34:45

标签: php mysql mongodb phalcon

我认为我的问题需要一个数据透视表,但我想在花费大量时间尝试实现之前要清楚。我还没有为任何项目使用数据透视表。

我有一个新项目,其中包含多个“套件”,其中包含常见的“部件”,在某些情况下,部件可以与另一个套件的部件互换。同样地,并非所有部件都彼此兼容。

我不希望创建一些噩梦般的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 中进行编码。

感谢您的意见和建议。

史蒂芬

1 个答案:

答案 0 :(得分:0)

假设您有23个套件和512个不同的部件。如何定义套件1使用零件A,B和C,而套件2使用零件A,D,E和F?数据透视表是定义每个工具包及其部件之间关系的好方法。一旦你有了一个Kits表,一个Parts表和一个KitParts表,那么你可以将这三个表连在一起以便于查询。一旦加入成为你的第二天性,他们实际上很乐意与你合作。

就PhalconPHP而言,hasManybelongsTonote 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";
}