【发布时间】:2015-01-26 08:30:29
【问题描述】:
我已经像这样使用迁移创建了一个表:
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]:一般错误:1025 重命名错误 './dev_iwms_reboot/despatch_discrepancies' 到 './dev_iwms_reboot/#sql2-67c-17c464' (errno: 152) (SQL: alter tabledespatch_discrepanciesdrop外键pick_detail_id)[PDO异常]
SQLSTATE [HY000]:一般错误:1025 重命名错误 './dev_iwms_reboot/despatch_discrepancies' 到 './dev_iwms_reboot/#sql2-67c-17c464' (errno: 152)
当我尝试通过运行 php artisan migrate:rollback 命令来反转此迁移时,我收到了 Rolled back 消息,但它实际上并没有在数据库中执行任何操作。
知道可能出了什么问题吗?如何删除具有外键引用的列?
【问题讨论】:
标签: php laravel laravel-4 database-migration