作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
class UpdateSessions extends Migration {
public function up()
{
Schema::table('sessions', function($table){
$table->string('comCode')->nullable()->change();
});
}
public function down()
{
// What should i write here?
}
}
我已经创建了一个 session 表,编写了一个迁移以将列更改为可为空。现在我很困惑我应该写什么?
最佳答案
在迁移的 down
方法中,您可以撤消在 up
方法中所做的更改。当您使用 artisan migrate:rollback 命令回滚迁移时,会调用此方法。在你的情况下,它看起来像这样:
public function down()
{
// Laravel doesn't have a method to undo ->nullable()
// so you have to do use a raw query in this case
DB::statement('ALTER TABLE sessions MODIFY comCode VARCHAR(255) NOT NULL');
}
因此,如果在迁移 up
中,您将名为 comCode
的列修改为可为空,则在回滚迁移时,您需要更新该列定义以使其可以为空。 not null,这就是您在 down
方法中所做的事情。
为了使迁移成功运行,down
方法中不需要包含任何内容,但是一旦迁移运行,您将无法将其回滚,除非您有正确的配置down
方法中的代码。
关于laravel - laravel 中的迁移中是否有必要为每个 up() 都写 down() ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28738684/
我正在使用 this solution在二进制矩阵中找到与图像边界对齐的矩形。假设现在我想找到一个不与图像边框对齐的矩形,并且我不知道它的方向;找到它的最快方法是什么? 为了示例,让我们寻找一个仅包含
else: 行在这个 Python 程序中是否正确/必要? from random import randrange for n in range(10): r = randrange(0,1
在 TDPL 7.1.5.1 中讨论了将 Widget w2 分配给 w1 并且作者指出“将 w2 逐个字段分配给 w1 会将 w2.array 分配给 w1.array——一个简单的数组边界分配,而
我是一名优秀的程序员,十分优秀!