20260519011303_ConvertProcessStepToEnum.cs 4.78 KB
using Microsoft.EntityFrameworkCore.Migrations;

#nullable disable

namespace RobotProductionSystem.Api.Infrastructure.Migrations
{
    /// <inheritdoc />
    public partial class ConvertProcessStepToEnum : Migration
    {
        /// <inheritdoc />
        protected override void Up(MigrationBuilder migrationBuilder)
        {
            migrationBuilder.Sql(
                """
                ALTER TABLE sn_items
                ALTER COLUMN "CurrentStep" TYPE integer
                USING CASE lower(trim("CurrentStep"))
                    WHEN '装配' THEN 1
                    WHEN 'assembly' THEN 1
                    WHEN '调试' THEN 2
                    WHEN 'debug' THEN 2
                    WHEN '测试' THEN 3
                    WHEN 'test' THEN 3
                    WHEN 'testing' THEN 3
                    WHEN '终检' THEN 4
                    WHEN 'final_inspection' THEN 4
                    WHEN 'final-inspection' THEN 4
                    WHEN 'finalinspection' THEN 4
                    WHEN '返修' THEN 5
                    WHEN 'rework' THEN 5
                    WHEN '入库' THEN 6
                    WHEN 'warehousing' THEN 6
                    WHEN 'warehouse' THEN 6
                    ELSE 0
                END;
                """);

            migrationBuilder.Sql(
                """
                ALTER TABLE sn_events
                ALTER COLUMN "CurrentStep" TYPE integer
                USING CASE lower(trim("CurrentStep"))
                    WHEN '装配' THEN 1
                    WHEN 'assembly' THEN 1
                    WHEN '调试' THEN 2
                    WHEN 'debug' THEN 2
                    WHEN '测试' THEN 3
                    WHEN 'test' THEN 3
                    WHEN 'testing' THEN 3
                    WHEN '终检' THEN 4
                    WHEN 'final_inspection' THEN 4
                    WHEN 'final-inspection' THEN 4
                    WHEN 'finalinspection' THEN 4
                    WHEN '返修' THEN 5
                    WHEN 'rework' THEN 5
                    WHEN '入库' THEN 6
                    WHEN 'warehousing' THEN 6
                    WHEN 'warehouse' THEN 6
                    ELSE 0
                END;
                """);

            migrationBuilder.Sql(
                """
                ALTER TABLE operation_tasks
                ALTER COLUMN "StepName" TYPE integer
                USING CASE lower(trim("StepName"))
                    WHEN '装配' THEN 1
                    WHEN 'assembly' THEN 1
                    WHEN '调试' THEN 2
                    WHEN 'debug' THEN 2
                    WHEN '测试' THEN 3
                    WHEN 'test' THEN 3
                    WHEN 'testing' THEN 3
                    WHEN '终检' THEN 4
                    WHEN 'final_inspection' THEN 4
                    WHEN 'final-inspection' THEN 4
                    WHEN 'finalinspection' THEN 4
                    WHEN '返修' THEN 5
                    WHEN 'rework' THEN 5
                    WHEN '入库' THEN 6
                    WHEN 'warehousing' THEN 6
                    WHEN 'warehouse' THEN 6
                    ELSE 0
                END;
                """);
        }

        /// <inheritdoc />
        protected override void Down(MigrationBuilder migrationBuilder)
        {
            migrationBuilder.Sql(
                """
                ALTER TABLE sn_items
                ALTER COLUMN "CurrentStep" TYPE text
                USING CASE "CurrentStep"
                    WHEN 1 THEN '装配'
                    WHEN 2 THEN '调试'
                    WHEN 3 THEN '测试'
                    WHEN 4 THEN '终检'
                    WHEN 5 THEN '返修'
                    WHEN 6 THEN '入库'
                    ELSE '未知'
                END;
                """);

            migrationBuilder.Sql(
                """
                ALTER TABLE sn_events
                ALTER COLUMN "CurrentStep" TYPE text
                USING CASE "CurrentStep"
                    WHEN 1 THEN '装配'
                    WHEN 2 THEN '调试'
                    WHEN 3 THEN '测试'
                    WHEN 4 THEN '终检'
                    WHEN 5 THEN '返修'
                    WHEN 6 THEN '入库'
                    ELSE '未知'
                END;
                """);

            migrationBuilder.Sql(
                """
                ALTER TABLE operation_tasks
                ALTER COLUMN "StepName" TYPE text
                USING CASE "StepName"
                    WHEN 1 THEN '装配'
                    WHEN 2 THEN '调试'
                    WHEN 3 THEN '测试'
                    WHEN 4 THEN '终检'
                    WHEN 5 THEN '返修'
                    WHEN 6 THEN '入库'
                    ELSE '未知'
                END;
                """);
        }
    }
}