J'essaie actuellement de recréer l'exemple, dans la documentation http://ef.readthedocs.org/en/latest/getting-started/uwp.html , en utilisant EF7 et SQLite pour créer une application de plate-forme universelle Windows.
J'ai installé le package de commandes EF7 et EF7 requis et créé le modèle et le contexte:
public class BloggingContext : DbContext
{
public DbSet<Blog> Blogs { get; set; }
public DbSet<Post> Posts { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
string dirPath = ApplicationData.Current.LocalFolder.Path;
string connectionString = "Filename=" + Path.Combine(dirPath, "blogging.db");
optionsBuilder.UseSqlite(connectionString);
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
}
}
public class Blog
{
public int BlogId { get; set; }
public string Url { get; set; }
public List<Post> Posts { get; set; }
}
public class Post
{
public int PostId { get; set; }
public string Title { get; set; }
public string Content { get; set; }
public int BlogId { get; set; }
public Blog Blog { get; set; }
}
Mon problème actuel est qu’après la construction de la solution, la commande qui doit échafauder une migration pour créer le jeu initial de tables de mon modèle échoue avec l’exception suivante:
PM> Add-Migration MyFirstMigration
System.Reflection.ReflectionTypeLoadException: Unable to load one or more of the requested types. Retrieve the LoaderExceptions property for more information.
at System.Reflection.RuntimeModule.GetTypes(RuntimeModule module)
at System.Reflection.RuntimeAssembly.get_DefinedTypes()
at Microsoft.Data.Entity.Design.Internal.StartupInvoker..ctor(String startupAssemblyName, String environment)
at Microsoft.Data.Entity.Design.DbContextOperations..ctor(ILoggerProvider loggerProvider, String assemblyName, String startupAssemblyName, String environment)
at Microsoft.Data.Entity.Design.MigrationsOperations..ctor(ILoggerProvider loggerProvider, String assemblyName, String startupAssemblyName, String environment, String projectDir, String rootNamespace)
at Microsoft.Data.Entity.Design.OperationExecutor.<>c__DisplayClass3_0.<.ctor>b__3()
at Microsoft.Data.Entity.Internal.LazyRef`1.get_Value()
at Microsoft.Data.Entity.Design.OperationExecutor.<AddMigrationImpl>d__7.MoveNext()
at System.Linq.Buffer`1..ctor(IEnumerable`1 source)
at System.Linq.Enumerable.ToArray[TSource](IEnumerable`1 source)
at Microsoft.Data.Entity.Design.OperationExecutor.OperationBase.<>c__DisplayClass4_0`1.<Execute>b__0()
at Microsoft.Data.Entity.Design.OperationExecutor.OperationBase.Execute(Action action)
Unable to load one or more of the requested types. Retrieve the LoaderExceptions property for more information.
Quelqu'un at-il une solution à ce problème? Merci d'avance
Dans mon cas, la solution au problème consistait à créer la base de données et les tables à l'aide de code dans le fichier app.xaml, avant le démarrage de l'application.
using (var db = new BloggingContext())
{
db.Database.EnsureCreated();
db.Database.Migrate();
}
Contexte + Modèle:
public class BloggingContext : DbContext
{
public DbSet<Blog> Blogs { get; set; }
public DbSet<Post> Posts { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
string path = ApplicationData.Current.LocalFolder.Path;
if (!File.Exists(Path.Combine(path, "blogging.db")))
{
File.Create(Path.Combine(path, "blogging.db"));
}
optionsBuilder.UseSqlite("Data Source=" + Path.Combine(path, "blogging.db")+";");
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
// Make Blog.Url required
modelBuilder.Entity<Blog>()
.Property(b => b.Url)
.IsRequired();
}
}
[Table("Blog")]
public class Blog
{
[Key]
public int BlogId { get; set; }
[MaxLength(100)]
public string Url { get; set; }
public List<Post> Posts { get; set; }
}
[Table("Post")]
public class Post
{
[Key]
public int PostId { get; set; }
[MaxLength(30)]
public string Title { get; set; }
[MaxLength(250)]
public string Content { get; set; }
public int BlogId { get; set; }
[ForeignKey("BlogId")]
public Blog Blog { get; set; }
}
De plus, avant d’accéder à la base de données, je vérifie que celle-ci a été créée, par exemple:
using (var db = new BloggingContext())
{
db.Database.EnsureCreated();
Blogs.ItemsSource = db.Blogs.ToList();
}