2013-10-05 32 views
0

我建设上的Visual Studio 2012年实体框架不工作作为SaveChanges()桌面基础的应用发生它没有给出一个例外,似乎数据已经输入,但刷新后数据库中没有添加额外的行。实体框架是不是在N层架构的工作

对于演示中,我提出2层结构。

  • 查看
  • 数据访问层

我的看法是......

public partial class Form1 : Form 
    { 
     public Form1() 
     { 
      InitializeComponent(); 
     } 

     private void button1_Click(object sender, EventArgs e) 
     { 
      MyDAL dal = new MyDAL(); 
      if (dal.Add(StudentName.Text, Contact.Text)) 
      { 
       MessageBox.Show("Addition Successfull"); 
      } 
      else 
      { 
       MessageBox.Show("Addition Failed"); 
      } 
     } 
    } 

我的数据访问层........

public class MyDAL 
    { 
     public bool Add(string name, string contact) 
     { 
      using (var db = new Database1Entities()) 
      { 
       Student s = new Student(); 
       s.StudentName = name; 
       s.ContactNo = contact; 

       try 
       { 
        db.Students.Add(s); 
        db.SaveChanges(); 
        return true; 
       } 
       catch (Exception ex) 
       { 
        return false; 
       } 
      } 
     } 
    } 

和我的数据库脚本是.....

CREATE TABLE [dbo].[Student] (
    [Student_Id] INT   IDENTITY (1, 1) NOT NULL, 
    [StudentName] VARCHAR (50) NULL, 
    [ContactNo] VARCHAR (50) NULL, 
    PRIMARY KEY CLUSTERED ([Student_Id] ASC) 
); 

我App.Config中在查看

<?xml version="1.0" encoding="utf-8" ?> 
<configuration> 
    <startup> 
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" /> 
    </startup> 
    <connectionStrings> 
    <add name="Database1Entities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=(LocalDB)\v11.0;attachdbfilename=|DataDirectory|\Database1.mdf;integrated security=True;connect timeout=30;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" /> 
    </connectionStrings> 
</configuration> 

我App.Config中在DAL是....

<?xml version="1.0" encoding="utf-8"?> 
<configuration> 
    <configSections> 
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 --> 
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=5.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" /> 
    </configSections> 
    <connectionStrings> 
    <add name="Database1Entities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=(LocalDB)\v11.0;attachdbfilename=|DataDirectory|\Database1.mdf;integrated security=True;connect timeout=30;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" /> 
    </connectionStrings> 
    <entityFramework> 
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework"> 
     <parameters> 
     <parameter value="v11.0" /> 
     </parameters> 
    </defaultConnectionFactory> 
    </entityFramework> 
</configuration> 

回答

1

它如预期运行。这是对|DataDirectory|选项的一个简单误解。

当你编译你的解决方案,该数据库被复制到\Debug\|DataDirectory|有文件被修改。

很可能您正在查看解决方案中的文件(视觉工作室),这是而不是正在由Debug目录中的可执行文件修改。

+0

所以,我怎么能得到修改数据库'调试folder'存在于浏览以及在DAL ... – ButtGenius

+0

非常感谢'Erik' ......你让我的日子。).......我更改了| DataDirectory |与数据库的绝对路径和它按预期完美工作 – ButtGenius