最佳答案
我使用如下迁移创建了一个表:
public function up()
{
Schema::create('despatch_discrepancies', function($table) {
$table->increments('id')->unsigned();
$table->integer('pick_id')->unsigned();
$table->foreign('pick_id')->references('id')->on('picks');
$table->integer('pick_detail_id')->unsigned();
$table->foreign('pick_detail_id')->references('id')->on('pick_details');
$table->integer('original_qty')->unsigned();
$table->integer('shipped_qty')->unsigned();
});
}
public function down()
{
Schema::drop('despatch_discrepancies');
}
我需要更改这个表,删除外键引用 & 列 pick_detail_id
,并在 pick_id
列之后添加一个名为 sku
的新 varchar 列。
所以,我创建了另一个迁移,看起来像这样:
public function up()
{
Schema::table('despatch_discrepancies', function($table)
{
$table->dropForeign('pick_detail_id');
$table->dropColumn('pick_detail_id');
$table->string('sku', 20)->after('pick_id');
});
}
public function down()
{
Schema::table('despatch_discrepancies', function($table)
{
$table->integer('pick_detail_id')->unsigned();
$table->foreign('pick_detail_id')->references('id')->on('pick_details');
$table->dropColumn('sku');
});
}
当我运行这个迁移时,会得到以下错误:
[照明数据库查询异常]
SQLSTATE [ HY000] : 常见错误: 重命名为 ’./dev _ iwms _ reboot/despatch _ different’到 ’./dev _ iwms _ reboot/# sql2-67c-17c464’(errno: 152)(SQL: alter tabledespatch_discrepancies
删除外键 pick _ Details _ id)[ PDOException ]
SQLSTATE [ HY000] : 常见错误: 重命名为 ’./dev _ iwms _ reboot/despatch _ different’到 ’./dev _ iwms _ reboot/# sql2-67c-17c464’(errno: 152)
当我试图通过运行 php artisan migrate:rollback
命令来逆转这种迁移时,我得到了一条 Rolled back
消息,但它实际上并没有在数据库中做任何事情。
知道哪里出错了吗? 如何删除具有外键引用的列?