如何解决laravel migration change column type double to string:下函数
我正在尝试将列类型从double(8,2)
修改为varchar
。
自从文档中提到以来,它不允许更改double
,所以我尝试使用raw
语句。
public function up()
{
DB::statement('ALTER TABLE dmf_product_match_unmatches MODIFY s_price VARCHAR(191)');
DB::statement('ALTER TABLE dmf_product_match_unmatches MODIFY r_price VARCHAR(191)');
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
//
}
所以我的问题是在down
方法中我需要提到什么?
解决方法
如果您不使用down方法编写代码,则在回滚时s_price和r_price在架构中将具有VARCHAR(191)但没有double(8,2)。
运行时,下面的down()方法会将s_price和r_price还原为DOUBLE(8,2)
php artisan migration:rollback
public function down()
{
DB::statement('ALTER TABLE dmf_product_match_unmatches MODIFY s_price DOUBLE(8,2)');
DB::statement('ALTER TABLE dmf_product_match_unmatches MODIFY r_price DOUBLE(8,2)');
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。