本文整理匯總了PHP中Cake\ORM\Table::belongsToMany方法的典型用法代碼示例。如果您正苦於以下問題:PHP Table::belongsToMany方法的具體用法?PHP Table::belongsToMany怎麽用?PHP Table::belongsToMany使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Cake\ORM\Table
的用法示例。
在下文中一共展示了Table::belongsToMany方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: _generateTargetAssociations
/**
* Generate reciprocal associations as necessary.
*
* Generates the following associations:
*
* - target hasMany junction e.g. Articles hasMany ArticlesTags
* - target belongsToMany source e.g Articles belongsToMany Tags.
*
* You can override these generated associations by defining associations
* with the correct aliases.
*
* @param \Cake\ORM\Table $junction The junction table.
* @param \Cake\ORM\Table $source The source table.
* @param \Cake\ORM\Table $target The target table.
* @return void
*/
protected function _generateTargetAssociations($junction, $source, $target)
{
$junctionAlias = $junction->alias();
$sAlias = $source->alias();
if (!$target->association($junctionAlias)) {
$target->hasMany($junctionAlias, ['targetTable' => $junction, 'foreignKey' => $this->targetForeignKey()]);
}
if (!$target->association($sAlias)) {
$target->belongsToMany($sAlias, ['sourceTable' => $target, 'targetTable' => $source, 'foreignKey' => $this->targetForeignKey(), 'targetForeignKey' => $this->foreignKey(), 'through' => $junction, 'conditions' => $this->conditions()]);
}
}
示例2: testBelongsToMany
/**
* Tests that BelongsToMany() creates and configures correctly the association
*
* @return void
*/
public function testBelongsToMany()
{
$options = ['foreignKey' => 'thing_id', 'joinTable' => 'things_tags', 'conditions' => ['b' => 'c'], 'sort' => ['foo' => 'asc']];
$table = new Table(['table' => 'authors', 'connection' => $this->connection]);
$belongsToMany = $table->belongsToMany('tag', $options);
$this->assertInstanceOf('Cake\\ORM\\Association\\BelongsToMany', $belongsToMany);
$this->assertSame($belongsToMany, $table->association('tag'));
$this->assertEquals('tag', $belongsToMany->name());
$this->assertEquals('thing_id', $belongsToMany->foreignKey());
$this->assertEquals(['b' => 'c'], $belongsToMany->conditions());
$this->assertEquals(['foo' => 'asc'], $belongsToMany->sort());
$this->assertSame($table, $belongsToMany->source());
$this->assertSame('things_tags', $belongsToMany->junction()->table());
}