@@ 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 | /** |
@@ 1290-1314 (lines=25) @@ | ||
1287 | * @param \Phinx\Db\Table\ForeignKey $foreignKey |
|
1288 | * @return string |
|
1289 | */ |
|
1290 | protected function getForeignKeySqlDefinition(ForeignKey $foreignKey) |
|
1291 | { |
|
1292 | $def = ''; |
|
1293 | if ($foreignKey->getConstraint()) { |
|
1294 | $def .= ' CONSTRAINT ' . $this->quoteColumnName($foreignKey->getConstraint()); |
|
1295 | } else { |
|
1296 | $columnNames = []; |
|
1297 | foreach ($foreignKey->getColumns() as $column) { |
|
1298 | $columnNames[] = $this->quoteColumnName($column); |
|
1299 | } |
|
1300 | $def .= ' FOREIGN KEY (' . implode(',', $columnNames) . ')'; |
|
1301 | $refColumnNames = []; |
|
1302 | foreach ($foreignKey->getReferencedColumns() as $column) { |
|
1303 | $refColumnNames[] = $this->quoteColumnName($column); |
|
1304 | } |
|
1305 | $def .= ' REFERENCES ' . $this->quoteTableName($foreignKey->getReferencedTable()->getName()) . ' (' . implode(',', $refColumnNames) . ')'; |
|
1306 | if ($foreignKey->getOnDelete()) { |
|
1307 | $def .= ' ON DELETE ' . $foreignKey->getOnDelete(); |
|
1308 | } |
|
1309 | if ($foreignKey->getOnUpdate()) { |
|
1310 | $def .= ' ON UPDATE ' . $foreignKey->getOnUpdate(); |
|
1311 | } |
|
1312 | } |
|
1313 | ||
1314 | return $def; |
|
1315 | } |
|
1316 | ||
1317 | /** |