本文整理匯總了PHP中Propel\Generator\Model\ForeignKey::getForeignColumnObjects方法的典型用法代碼示例。如果您正苦於以下問題:PHP ForeignKey::getForeignColumnObjects方法的具體用法?PHP ForeignKey::getForeignColumnObjects怎麽用?PHP ForeignKey::getForeignColumnObjects使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Propel\Generator\Model\ForeignKey
的用法示例。
在下文中一共展示了ForeignKey::getForeignColumnObjects方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: testForeignKeyIsForeignPrimaryKey
public function testForeignKeyIsForeignPrimaryKey()
{
$database = $this->getDatabaseMock('bookstore');
$platform = $this->getPlatformMock();
$foreignTable = $this->getTableMock('authors');
$localTable = $this->getTableMock('books', ['platform' => $platform, 'database' => $database]);
$idColumn = $this->getColumnMock('id');
$authorIdColumn = $this->getColumnMock('author_id');
$database->expects($this->any())->method('getTable')->with($this->equalTo('authors'))->will($this->returnValue($foreignTable));
$foreignTable->expects($this->once())->method('getPrimaryKey')->will($this->returnValue([$idColumn]));
$foreignTable->expects($this->any())->method('getColumn')->with($this->equalTo('id'))->will($this->returnValue($idColumn));
$localTable->expects($this->any())->method('getColumn')->with($this->equalTo('author_id'))->will($this->returnValue($authorIdColumn));
$fk = new ForeignKey();
$fk->setTable($localTable);
$fk->setForeignTableCommonName('authors');
$fk->addReference('author_id', 'id');
$fkMapping = $fk->getColumnObjectsMapping();
$this->assertTrue($fk->isForeignPrimaryKey());
$this->assertCount(1, $fk->getForeignColumnObjects());
$this->assertSame($authorIdColumn, $fkMapping[0]['local']);
$this->assertSame($idColumn, $fkMapping[0]['foreign']);
$this->assertSame($idColumn, $fk->getForeignColumn(0));
}
示例2: getForeignKeyDDL
public function getForeignKeyDDL(ForeignKey $fk)
{
if ($fk->isSkipSql() || $fk->isPolymorphic()) {
return;
}
$pattern = 'CONSTRAINT %s FOREIGN KEY (%s) REFERENCES %s (%s)';
$script = sprintf($pattern, $this->quoteIdentifier($fk->getName()), $this->getColumnListDDL($fk->getLocalColumnObjects()), $this->quoteIdentifier($fk->getForeignTableName()), $this->getColumnListDDL($fk->getForeignColumnObjects()));
if ($fk->hasOnUpdate() && $fk->getOnUpdate() != ForeignKey::SETNULL) {
$script .= ' ON UPDATE ' . $fk->getOnUpdate();
}
if ($fk->hasOnDelete() && $fk->getOnDelete() != ForeignKey::SETNULL) {
$script .= ' ON DELETE ' . $fk->getOnDelete();
}
return $script;
}
示例3: getForeignKeyDDL
public function getForeignKeyDDL(ForeignKey $fk)
{
if ($fk->isSkipSql() || $fk->isPolymorphic()) {
return;
}
$pattern = "CONSTRAINT %s\n FOREIGN KEY (%s) REFERENCES %s (%s)";
$script = sprintf($pattern, $this->quoteIdentifier($fk->getName()), $this->getColumnListDDL($fk->getLocalColumnObjects()), $this->quoteIdentifier($fk->getForeignTableName()), $this->getColumnListDDL($fk->getForeignColumnObjects()));
if ($fk->hasOnDelete()) {
$script .= "\n ON DELETE " . $fk->getOnDelete();
}
return $script;
}
示例4: getForeignKeyDDL
public function getForeignKeyDDL(ForeignKey $fk)
{
if ($fk->isSkipSql() || !$this->foreignKeySupport) {
return;
}
$pattern = "FOREIGN KEY (%s) REFERENCES %s (%s)";
$script = sprintf($pattern, $this->getColumnListDDL($fk->getLocalColumnObjects()), $this->quoteIdentifier($fk->getForeignTableName()), $this->getColumnListDDL($fk->getForeignColumnObjects()));
if ($fk->hasOnUpdate()) {
$script .= "\n ON UPDATE " . $fk->getOnUpdate();
}
if ($fk->hasOnDelete()) {
$script .= "\n ON DELETE " . $fk->getOnDelete();
}
return $script;
}