C# EF savechanges()不影响my.mdf DB

C# EF savechanges()不影响my.mdf DB,c#,database,entity-framework,mdf,C#,Database,Entity Framework,Mdf,我的.mdf数据库中有此模型: 这两个表没有数据: PersonID是一个外键 这是我的EF模型图: 这是添加一个人的代码 namespace DBTest { class Class1 { MyDBEntities db; public Class1() { db = new MyDBEntities(); AddPerson(); }

我的.mdf数据库中有此模型:

这两个表没有数据:

PersonID是一个外键

这是我的EF模型图:

这是添加一个人的代码

    namespace DBTest
{
    class Class1
    {
        MyDBEntities db;
        public Class1()
        {
            db = new MyDBEntities();
            AddPerson();
        }        


        void AddPerson()
        {
            Person p = new Person();
            p.ID=1;
            p.NAME="abcd";
            db.AddToPerson(p);
            db.SaveChanges();
        }
    }
}
在我从主界面调用该类之后:

    namespace DBTest
{
    class Program
    {
        static void Main(string[] args)
        {
            Class1 a = new Class1();
        }
    }
}
我想看看我的.mdf数据库是否有任何更改。
我发现数据库仍然为空(刷新后):

有人知道我需要做什么来更新数据库吗? 我做错了什么

编辑:

连接字符串:

    <connectionStrings>
    <add name="DBTest.Properties.Settings.XXXXConnectionString" connectionString="Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\XXXX.mdf;Integrated Security=True;User Instance=True" providerName="System.Data.SqlClient" />
    <add name="MyDBEntities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string=&quot;Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\MyDB.mdf;Integrated Security=True;User Instance=True;MultipleActiveResultSets=True&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>

您没有向我们显示您的连接字符串,但我只是从您报告的“症状”中猜测

整个用户实例和AttachDbFileName=方法都有缺陷-最多!在Visual Studio中运行应用程序时,它将围绕
.mdf
文件进行复制(从
app\u Data
目录复制到输出目录-通常是
\bin\debug
-应用程序运行的地方)和最有可能是,您的
INSERT
工作正常-但您最后看到的是错误的.mdf文件

如果您想继续使用这种方法,请尝试在
myConnection.Close()
调用上放置一个断点,然后使用SQL Server Mgmt Studio Express检查
.mdf
文件,我几乎可以肯定您的数据在那里

我认为真正的解决办法是

  • 安装SQL Server Express(您已经完成了安装)

  • 安装SQL Server Management Studio Express

  • 在SSMS Express中创建数据库,并为其指定一个逻辑名称(例如
    MyDB

  • 使用其逻辑数据库名称连接到它(在服务器上创建时提供),不要乱动物理数据库文件和用户实例。在这种情况下,您的连接字符串类似于:

    Data Source=.\\SQLEXPRESS;Database=MyDB;Integrated Security=True
    
    其他一切都和以前一样


  • 你找到解决这个问题的办法了吗?我在VS中使用了数据库,遇到了和您描述的相同的问题。你能解释一下你是如何解决这个问题的吗?