コードは簡単です。 Tag.cs
エンティティ:
public partial class Tag
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
}
HomeController.cs
クラス:
public async Task<IActionResult> Index()
{
tagRepository.Insert(new Tag
{
Name = "name",
Description = "description"
});
await UnitOfWork.SaveChangesAsync(); // calls dbContext.SaveChangesAsync()
return View();
}
TagRepository.cs
クラス:
// Context it's a usual DBContext injected via Repository's constructor
public virtual void Insert(TEntity item)
=> Context.Entry(item).State = EntityState.Added;
Tag
テーブルは次を実行して作成されました:
CREATE TABLE Tag (
ID SERIAL PRIMARY KEY,
Name text NOT NULL,
Description text NULL
);
アプリケーションを実行すると、エラーが発生します。
fail: Microsoft.EntityFrameworkCore.Database.Command[20102]
Failed executing DbCommand (28ms) [Parameters=[@p0='?', @p1='?', @p2='?'], CommandType='Text', CommandTimeout='30']
INSERT INTO "tag" ("id", "description", "name")
VALUES (@p0, @p1, @p2);
Npgsql.PostgresException (0x80004005): 23505: duplicate key value violates unique constraint "tag_pkey"
at Npgsql.NpgsqlConnector.<DoReadMessage>d__157.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()
at System.Runtime.CompilerServices.ValueTaskAwaiter`1.GetResult()
at Npgsql.NpgsqlConnector.<ReadMessage>d__156.MoveNext()
ご覧のとおり、Entity Frameworkはid=0
の値はDBですが、id=0
私のDBで、それがスローされる理由duplicate key
エラー。
これまでのところ答えが見つかりませんでした。私の質問は、このエラーを取り除き、id
列が自動インクリメントされ、更新する必要がないことをEntity Frameworkに伝えるにはどうすればよいですか?
ここで使用する必要があります "ValueGenerationOnAdd()"。発生している問題は既にGitHubで報告されています。以下のリンクを見つけてください。
https://github.com/npgsql/Npgsql.EntityFrameworkCore.PostgreSQL/issues/7
次のリンクから、生成値パターンに関する詳細情報を見つけることができます。
public classs SampleContext:DBContext{
public DbSet<Tag> Tag { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder){
modelBuilder.Entity<Tag>()
.Property(p => p.ID)
.ValueGeneratedOnAdd();
}
public class Tag{
public int Id { get; set; }
public string Name { get; set; }
public string Description{get;set;}
}
}
ソース: https://www.learnentityframeworkcore.com/configuration/fluent-api/valuegeneratedonadd-method
これが役立つことを願って