Non so se si tratta di una scelta di scelta di Entity Framework o di un approccio errato per conto mio, ma ogni volta che provo ad aggiungere le entità ad un DbSet non riesco a ottenere i campi IDENTITY generati automaticamente.
[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: Ecco il codice aggiornato per mostrare cosa stava causando il problema: enumerables. Non è necessario aggiungere altri attributi alle classi di entità.
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);
}
Qual è stata la causa del problema? Enumerables! Dai un'occhiata alla sezione EDIT nella mia domanda per la soluzione.
Sto usando Database First in EF 6, e dopo aver provato per un periodo di tempo, trovo una possibile soluzione.
Innanzitutto, controlla la tabella nel database, assicurati di aver definito la colonna 'ID' come un campo chiave primaria a incremento automatico, che può essere dichiarato utilizzando qualcosa di simile
ID int IDENTITY(1,1) PRIMARY KEY,
quando crei il tuo tavolo. Alcune informazioni correlate possono vedere qui1 o qui2 .
oppure puoi controllare le proprietà dei dati in IDE MSSQL come:
Secondo, imposta StoreGeneratedPattern della colonna 'ID' come Identità , puoi farlo aprendo il file edmx in Visual Studio, fai clic con il tasto destro del mouse sulla Colonna Dati nella tabella e seleziona Proprietà, e l'impostazione StoreGeneratedPattern è nella Finestra Proprietà:
Alcuni articoli correlati vedi qui .
Dopo aver completato le cose sopra, usando EF AddRange, l'ID si incrementa automaticamente e tutto funziona alla grande.
public class Entity
{
public long Id { get; set; }
public string Field { get; set; }
}
var entities = new Entity[]
{
new Entity() { Field = "A" },
new Entity() { Field = "B" },
};
_dbContext.Entities.AddRange(entities);