簡體   English   中英

具有EF CodeFirst的WPF MVVM

[英]WPF MVVM with EF CodeFirst

運行WPF應用程序時未創建數據庫。 我的代碼有什么問題:

在此處輸入圖片說明

App.config中

  <connectionStrings>
    <add name="JanathaPOSConn"
     connectionString="Server=.\SQLEXPRESS;Database=JanathaDb;Trusted_Connection=true"
     providerName="System.Data.SqlClient" />
  </connectionStrings>

POCO 1級:

namespace JanathaPOS.Model
{
    [Table("UserRoles")]
    public class UserRole
    {
        [Key]
        public string Id { get; set; }
        [MaxLength(50)]
        public string Name { get; set; }
        [MaxLength(50)]
        public string Description { get; set; }
    }
}

POCO 2類:

namespace JanathaPOS.Model
{
    [Table("Users")]
    public class User
    {
        [Key]
        public string Id { get; set; }
        [MaxLength(50)]
        public string Name { get; set; }
    }
}

上下文類:

namespace JanathaPOS.Model
{
    /// <summary>
    /// 
    /// </summary>
    class JanathaPosDbContext : DbContext
    {
        private static JanathaPosDbContext _context;

        /// <summary>
        /// 
        /// </summary>
        /// <returns></returns>
        public static JanathaPosDbContext GetContext()
        {
            if (_context == null)
            {
                _context = new JanathaPosDbContext();
            }
            return _context;
        }

        /// <summary>
        /// 
        /// </summary>
        public JanathaPosDbContext() : base("JanathaPOSConn") { }

        /// <summary>
        /// 
        /// </summary>
        /// <param name="modelBuilder"></param>
        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Entity<UserRole>();
            modelBuilder.Entity<User>();

            base.OnModelCreating(modelBuilder);
        }

        public DbSet<UserRole> UserRoles { get; set; }
        public DbSet<User> Users { get; set; }

    }
}

XAML:

namespace JanathaPOS
{
    /// <summary>
    /// Interaction logic for App.xaml
    /// </summary>
    public partial class App : Application
    {
        protected override void OnStartup(StartupEventArgs e)
        {
            Database.SetInitializer(new DropCreateDatabaseIfModelChanges<JanathaPosDbContext>());

            base.OnStartup(e);
        }
    }
}

我看不到這里實例化的上下文。 您必須創建上下文並嘗試訪問數據強制初始化:

using ( var ctx = new JanathaPosDbContext() )
{
    // access the data 
    var roles = ctx.UserRoles.ToList();         

    // or force the initialization
    ctx.Database.Initialize( true );
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM