Ho un modello con Annotazioni dei dati e mi chiedevo se fosse possibile che il metodo SaveChanges fallisse se l'Annotazione dei dati falliva?
Mi aspettavo che SaveChanges lanciasse un'eccezione lungo le linee di "Test2 è al di fuori dell'intervallo da 2 a 4". Invece, salva nel database.
Ad esempio, ecco la mia entità di prova:
public class Visit
{
public int Id { get; set; }
[MaxLength(2)]
public string Test { get; set; }
[Range(2, 4)]
public int Test2 { get; set; }
}
Ecco il contesto:
public class Context : DbContext
{
public Context()
{
}
public Context(DbContextOptions<Context> options)
: base(options)
{
}
public DbSet<Visit> Visits { get; set; }
}
Ed ecco il semplicissimo metodo MVC Controller che sto usando per testarlo con:
public HomeController(Context context)
{
context.Visits.Add(new Visit() {Test = "21", Test2 = 3423});
var results = context.SaveChanges();
}
Ecco il mio file project.json:
{
"dependencies": {
"Microsoft.AspNetCore.Diagnostics": "1.0.0",
"Microsoft.AspNetCore.Mvc": "1.0.0",
"Microsoft.AspNetCore.Razor.Tools": {
"version": "1.0.0-preview2-final",
"type": "build"
},
"Microsoft.AspNetCore.Server.IISIntegration": "1.0.0",
"Microsoft.AspNetCore.Server.Kestrel": "1.0.0",
"Microsoft.AspNetCore.StaticFiles": "1.0.0",
"Microsoft.EntityFrameworkCore.SqlServer": "1.0.0",
"Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final",
"Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0",
"Microsoft.Extensions.Configuration.Json": "1.0.0",
"Microsoft.Extensions.Logging": "1.0.0",
"Microsoft.Extensions.Logging.Console": "1.0.0",
"Microsoft.Extensions.Logging.Debug": "1.0.0",
"Microsoft.Extensions.Options.ConfigurationExtensions": "1.0.0",
"Microsoft.NETCore.App": {
"version": "1.0.0",
"type": "platform"
},
"Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.0.0",
"System.ComponentModel.Annotations": "4.1.0"
},
"tools": {
"Microsoft.EntityFrameworkCore.Tools": "1.0.0-preview2-final",
"BundlerMinifier.Core": "2.0.238",
"Microsoft.AspNetCore.Razor.Tools": "1.0.0-preview2-final",
"Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final"
},
"frameworks": {
"netcoreapp1.0": {
"dependencies": {
},
"imports": [
"dotnet5.6",
"portable-net45+win8"
]
}
},
"buildOptions": {
"emitEntryPoint": true,
"preserveCompilationContext": true
},
"runtimeOptions": {
"configProperties": {
"System.GC.Server": true
}
},
"publishOptions": {
"include": [
"wwwroot",
"Views",
"Areas/**/Views",
"appsettings.json",
"web.config"
]
},
"scripts": {
"prepublish": [ "bower install", "dotnet bundle" ],
"postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ]
}
}
In base a un problema github correlato a questa domanda , Entity Framework Core non esegue convalide automatiche dei dati.
C'è un elenco aggiornato di funzionalità presenti in EF6 che non sono presenti in Core qui .
È possibile implementare la propria convalida ignorando SaveChanges:
class Context : DbContext
{
public override int SaveChanges()
{
var entities = from e in ChangeTracker.Entries()
where e.State == EntityState.Added
|| e.State == EntityState.Modified
select e.Entity;
foreach (var entity in entities)
{
var validationContext = new ValidationContext(entity);
Validator.ValidateObject(entity, validationContext);
}
return base.SaveChanges();
}
}
Ciò si valuterà contro le annotazioni di dati e genererà un'eccezione se la convalida non riesce.