1

我的 .mdf DB 上有这个模型:

在此处输入图像描述

这两个没有数据的表:

在此处输入图像描述

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>
4

1 回答 1

3

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

整个User Instance 和 AttachDbFileName=方法是有缺陷的 - 充其量!在 Visual Studio 中运行您的应用程序时,它将围绕.mdf文件进行复制(从您的App_Data目录到输出目录 - 通常.\bin\debug是您的应用程序运行的位置),并且很可能,您的INSERT工作正常 - 但您只是看错了 . mdf文件到底!

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

我认为真正的解决方案是

  1. 安装 SQL Server Express(反正你已经完成了)

  2. 安装 SQL Server Management Studio Express

  3. 在SSMS Express中创建您的数据库,给它一个逻辑名称(例如MyDB

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

    Data Source=.\\SQLEXPRESS;Database=MyDB;Integrated Security=True
    

    其他一切都和以前完全一样...

于 2013-04-14T19:57:34.890 回答