using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace GameDatabase.Migrations
{
///
public partial class SplitDifficultyArrays : Migration
{
///
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn(
name: "DifficultyPlayedCourse",
table: "UserData",
type: "INTEGER",
nullable: false,
defaultValue: 0u);
migrationBuilder.AddColumn(
name: "DifficultyPlayedSort",
table: "UserData",
type: "INTEGER",
nullable: false,
defaultValue: 0u);
migrationBuilder.AddColumn(
name: "DifficultyPlayedStar",
table: "UserData",
type: "INTEGER",
nullable: false,
defaultValue: 0u);
migrationBuilder.AddColumn(
name: "DifficultySettingCourse",
table: "UserData",
type: "INTEGER",
nullable: false,
defaultValue: 0u);
migrationBuilder.AddColumn(
name: "DifficultySettingSort",
table: "UserData",
type: "INTEGER",
nullable: false,
defaultValue: 0u);
migrationBuilder.AddColumn(
name: "DifficultySettingStar",
table: "UserData",
type: "INTEGER",
nullable: false,
defaultValue: 0u);
// Extract from json arrays
migrationBuilder.Sql(@"
UPDATE UserData
SET
DifficultyPlayedCourse = COALESCE(json_extract(DifficultyPlayedArray, '$[0]'), 0),
DifficultyPlayedStar = COALESCE(json_extract(DifficultyPlayedArray, '$[1]'), 0),
DifficultyPlayedSort = COALESCE(json_extract(DifficultyPlayedArray, '$[2]'), 0),
DifficultySettingCourse = COALESCE(json_extract(DifficultySettingArray, '$[0]'), 0),
DifficultySettingStar = COALESCE(json_extract(DifficultySettingArray, '$[1]'), 0),
DifficultySettingSort = COALESCE(json_extract(DifficultySettingArray, '$[2]'), 0);
");
}
///
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropColumn(
name: "DifficultyPlayedCourse",
table: "UserData");
migrationBuilder.DropColumn(
name: "DifficultyPlayedSort",
table: "UserData");
migrationBuilder.DropColumn(
name: "DifficultyPlayedStar",
table: "UserData");
migrationBuilder.DropColumn(
name: "DifficultySettingCourse",
table: "UserData");
migrationBuilder.DropColumn(
name: "DifficultySettingSort",
table: "UserData");
migrationBuilder.DropColumn(
name: "DifficultySettingStar",
table: "UserData");
}
}
}