in database/migrations/2017_10_14_083556_change_gift_column_structure.php [16:71]
public function up()
{
Schema::table('gifts', function (Blueprint $table) {
if (DBHelper::connection()->getDriverName() == 'pgsql') {
//Postgresql does not implicitly convert varchar's to integers, therefore add USING ...
DB::statement('ALTER TABLE gifts ALTER about_object_id TYPE INT USING about_object_id::integer');
} else {
$table->integer('about_object_id')->change();
}
});
Schema::table('gifts', function ($table) {
$table->dropColumn([
'about_object_type',
]);
});
Schema::table('gifts', function ($table) {
$table->boolean('is_is_an_idea')->after('is_an_idea');
$table->boolean('is_has_been_offered')->after('has_been_offered');
});
$gifts = DB::table('gifts')->get();
foreach ($gifts as $gift) {
if ($gift->is_an_idea == 'true') {
DB::table('gifts')
->where('id', $gift->id)
->update(['is_is_an_idea' => 1]);
} else {
DB::table('gifts')
->where('id', $gift->id)
->update(['is_is_an_idea' => 0]);
}
if ($gift->has_been_offered == 'true') {
DB::table('gifts')
->where('id', $gift->id)
->update(['is_has_been_offered' => 1]);
} else {
DB::table('gifts')
->where('id', $gift->id)
->update(['is_has_been_offered' => 0]);
}
}
Schema::table('gifts', function (Blueprint $table) {
$table->dropColumn('is_an_idea');
$table->dropColumn('has_been_offered');
});
Schema::table('gifts', function ($table) {
$table->renameColumn('is_is_an_idea', 'is_an_idea');
$table->renameColumn('is_has_been_offered', 'has_been_offered');
});
}