| @@ 1200-1223 (lines=24) @@ | ||
| 1197 | * @param \Phinx\Db\Table\ForeignKey $foreignKey |
|
| 1198 | * @return string |
|
| 1199 | */ |
|
| 1200 | protected function getForeignKeySqlDefinition(ForeignKey $foreignKey) |
|
| 1201 | { |
|
| 1202 | $def = ''; |
|
| 1203 | if ($foreignKey->getConstraint()) { |
|
| 1204 | $def .= ' CONSTRAINT ' . $this->quoteColumnName($foreignKey->getConstraint()); |
|
| 1205 | } |
|
| 1206 | $columnNames = []; |
|
| 1207 | foreach ($foreignKey->getColumns() as $column) { |
|
| 1208 | $columnNames[] = $this->quoteColumnName($column); |
|
| 1209 | } |
|
| 1210 | $def .= ' FOREIGN KEY (' . implode(',', $columnNames) . ')'; |
|
| 1211 | $refColumnNames = []; |
|
| 1212 | foreach ($foreignKey->getReferencedColumns() as $column) { |
|
| 1213 | $refColumnNames[] = $this->quoteColumnName($column); |
|
| 1214 | } |
|
| 1215 | $def .= ' REFERENCES ' . $this->quoteTableName($foreignKey->getReferencedTable()->getName()) . ' (' . implode(',', $refColumnNames) . ')'; |
|
| 1216 | if ($foreignKey->getOnDelete()) { |
|
| 1217 | $def .= ' ON DELETE ' . $foreignKey->getOnDelete(); |
|
| 1218 | } |
|
| 1219 | if ($foreignKey->getOnUpdate()) { |
|
| 1220 | $def .= ' ON UPDATE ' . $foreignKey->getOnUpdate(); |
|
| 1221 | } |
|
| 1222 | ||
| 1223 | return $def; |
|
| 1224 | } |
|
| 1225 | ||
| 1226 | /** |
|
| @@ 1343-1367 (lines=25) @@ | ||
| 1340 | * @param \Phinx\Db\Table\ForeignKey $foreignKey |
|
| 1341 | * @return string |
|
| 1342 | */ |
|
| 1343 | protected function getForeignKeySqlDefinition(ForeignKey $foreignKey) |
|
| 1344 | { |
|
| 1345 | $def = ''; |
|
| 1346 | if ($foreignKey->getConstraint()) { |
|
| 1347 | $def .= ' CONSTRAINT ' . $this->quoteColumnName($foreignKey->getConstraint()); |
|
| 1348 | } else { |
|
| 1349 | $columnNames = []; |
|
| 1350 | foreach ($foreignKey->getColumns() as $column) { |
|
| 1351 | $columnNames[] = $this->quoteColumnName($column); |
|
| 1352 | } |
|
| 1353 | $def .= ' FOREIGN KEY (' . implode(',', $columnNames) . ')'; |
|
| 1354 | $refColumnNames = []; |
|
| 1355 | foreach ($foreignKey->getReferencedColumns() as $column) { |
|
| 1356 | $refColumnNames[] = $this->quoteColumnName($column); |
|
| 1357 | } |
|
| 1358 | $def .= ' REFERENCES ' . $this->quoteTableName($foreignKey->getReferencedTable()->getName()) . ' (' . implode(',', $refColumnNames) . ')'; |
|
| 1359 | if ($foreignKey->getOnDelete()) { |
|
| 1360 | $def .= ' ON DELETE ' . $foreignKey->getOnDelete(); |
|
| 1361 | } |
|
| 1362 | if ($foreignKey->getOnUpdate()) { |
|
| 1363 | $def .= ' ON UPDATE ' . $foreignKey->getOnUpdate(); |
|
| 1364 | } |
|
| 1365 | } |
|
| 1366 | ||
| 1367 | return $def; |
|
| 1368 | } |
|
| 1369 | ||
| 1370 | /** |
|