diff --git a/src/EFCore.PG/Migrations/Internal/NpgsqlHistoryRepository.cs b/src/EFCore.PG/Migrations/Internal/NpgsqlHistoryRepository.cs index b0469daa9..3c8513ec3 100644 --- a/src/EFCore.PG/Migrations/Internal/NpgsqlHistoryRepository.cs +++ b/src/EFCore.PG/Migrations/Internal/NpgsqlHistoryRepository.cs @@ -98,7 +98,9 @@ bool IHistoryRepository.CreateIfNotExists() GetCreateIfNotExistsCommands(), Dependencies.Connection, new MigrationExecutionState(), commitTransaction: true) != 0; } - catch (PostgresException e) when (e.SqlState is "23505" or "42P07") + catch (PostgresException e) when (e.SqlState is PostgresErrorCodes.UniqueViolation + or PostgresErrorCodes.DuplicateTable + or PostgresErrorCodes.DuplicateObject) { return false; } @@ -116,7 +118,9 @@ async Task IHistoryRepository.CreateIfNotExistsAsync(CancellationToken can cancellationToken: cancellationToken).ConfigureAwait(false)) != 0; } - catch (PostgresException e) when (e.SqlState is "23505" or "42P07") + catch (PostgresException e) when (e.SqlState is PostgresErrorCodes.UniqueViolation + or PostgresErrorCodes.DuplicateTable + or PostgresErrorCodes.DuplicateObject) { return false; } @@ -192,7 +196,7 @@ public override IReadOnlyList GetAppliedMigrations() { return base.GetAppliedMigrations(); } - catch (PostgresException e) when (e.SqlState is "3D000" or "42P01") + catch (PostgresException e) when (e.SqlState is PostgresErrorCodes.InvalidCatalogName or PostgresErrorCodes.UndefinedTable) { return []; } @@ -210,7 +214,7 @@ public override async Task> GetAppliedMigrationsAsync( { return await base.GetAppliedMigrationsAsync(cancellationToken).ConfigureAwait(false); } - catch (PostgresException e) when (e.SqlState is "3D000" or "42P01") + catch (PostgresException e) when (e.SqlState is PostgresErrorCodes.InvalidCatalogName or PostgresErrorCodes.UndefinedTable) { return []; }