エンティティフレームワークの選択肢が間違っているかどうかわかりませんが、DbSetにAddRangeエンティティを追加しようとすると表示されません自動的に生成されたIDENTITYフィールドを取得します。Entity FrameworkでAddRangeを使用してIDENTITYを自動生成できない
[Table("entities")]
public class Entity
{
[Key]
[Column("id")]
public long Id { get; set; }
[Column("field")]
public string Field { get; set; }
}
var entities = new Entity[]
{
new Entity() { Field = "A" },
new Entity() { Field = "B" },
};
_dbContext.Entities.AddRange(entities);
await _dbContext.SaveChangesAsync();
//ids are still default(long) at this point!!
EDIT:enumerables: ここでは、問題を引き起こしていたかを示すために更新されたコードです。エンティティクラスに他の属性を追加する必要はありません。
public class Request
{
public string Field { get; set; }
public Entity ToEntity()
{
return new Entity() { Field = Field };
}
}
public async Task<IEnumerable<long>> SaveRequests(IEnumerable<Request> requests)
{
var entities = requests.Select(r => r.ToEntity()); //not working
var entities = requests.Select(r => r.ToEntity()).ToArray(); //working
_dbContext.Entities.AddRange(entities);
await _dbContext.SaveChangesAsync();
return entities.Select(e => e.Id);
}
[キー] [DatabaseGenerated(DatabaseGeneratedOption.Identity)] –
私は同じ問題をHAE、 VAR ADATA = referencias.Select(I => 新しいInternalClass() {/ * IdがAUTOGEN、*/... }); db.InternalClass.AddRange(aData); db.SaveChanges(); しかし、aData.FirstOrDefault()(id = 0)の新しいIDを取得することはできません なぜそれが起こるかについての詳細情報を見つけましたか? –