微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

laravel migration change column type double to string:下函数

如何解决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 举报,一经查实,本站将立刻删除。