コマンドラインでデータベースを更新していましたが、テーブルの1つを手動で更新しました。
これにより、データベースを更新する機能が中断されたようです。アップデートしようとすると、次のエラーが表示されます。
System.Data.SqlClient.SqlException: There is already an object named 'ClientsAndTestimonials' in the database. at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction)
at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj, Boolean callerHasConnectionLock, Boolean asyncClose)
at System.Data.SqlClient.TdsParser.TryRun(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj, Boolean& dataReady)
at System.Data.SqlClient.SqlCommand.RunExecuteNonQueryTds(String methodName, Boolean async, Int32 timeout, Boolean asyncWrite)
at System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource`1 completion, Boolean sendToPipe, Int32 timeout, Boolean asyncWrite, String methodName)
at System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
at Microsoft.EntityFrameworkCore.Storage.Internal.RelationalCommand.Execute(IRelationalConnection connection, String executeMethod, IReadOnlyDictionary`2 parameterValues, Boolean openConnection, Boolean closeConnection)
at Microsoft.EntityFrameworkCore.Storage.Internal.RelationalCommand.ExecuteNonQuery(IRelationalConnection connection, IReadOnlyDictionary`2 parameterValues, Boolean manageConnection)
at Microsoft.EntityFrameworkCore.Migrations.Internal.MigrationCommandExecutor.ExecuteNonQuery(IEnumerable`1 migrationCommands, IRelationalConnection connection)
at Microsoft.EntityFrameworkCore.Migrations.Internal.Migrator.Migrate(String targetMigration)
at Microsoft.EntityFrameworkCore.Design.MigrationsOperations.UpdateDatabase(String targetMigration, String contextType)
at Microsoft.EntityFrameworkCore.Tools.Cli.DatabaseUpdateCommand.<>c__DisplayClass0_0.<Configure>b__0()
at Microsoft.Extensions.CommandLineUtils.CommandLineApplication.Execute(String[] args)
at Microsoft.EntityFrameworkCore.Tools.Cli.Program.Main(String[] args)
ClientConnectionId:d89989a8-ce8b-4167-be7e-fcddc4bcdf98
Error Number:2714,State:6,Class:16
There is already an object named 'ClientsAndTestimonials' in the database.
過去数日間、この問題を解決しようと努めてきました。ほとんどの仲間の開発者は、次の link のJohn Salewskiのように、Add-migration "Reset" -IgnoreChangesを使用するいくつかのバリエーションを提案しています。
しかし、「パラメーター名 'IgnoreChanges'に一致するパラメーターが見つかりません」というエラーが表示され続けます。
どんな提案も大歓迎です!
Up()関数でAddColumnの代わりにAlter columnを使用します
migrationBuilder.AlterColumn<bool>(
name: "IsActive",
table: "Advertisements",
nullable: false,
defaultValue: true);
または
public override void Up()
{
AddColumn("dbo.Products", "Description", c => c.String(maxLength: 50));
}
asp.netの移行
データベースに十分な影響を与えたくない場合は、up関数の一部にコメントを付けることができます。
移行コマンドがそれらを作成するために怒った場合。移行をリセットしてリベースします。方法:visualstudioとsqlの両方から移行コンテンツを削除し、add-migration
再びupdate-database