0

Visual Studio 2012 でデスクトップ ベースのアプリケーションを構築しています。Entity Framework が動作しSaveChanges()ていないため、例外は発生しません。データが入力されたようですが、データベースを更新した後、余分な行が追加されません。

デモ用に、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>

DAL の私の App.Config は....

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

1 に答える 1

1

意図したとおりに動作しています。これは、|DataDirectory|オプションの単純な誤解です。

ソリューションをコンパイルすると、データベースが にコピーされ、\Debug\|DataDirectory|そこでファイルが変更されます。

ほとんどの場合、ディレクトリ内の実行可能ファイルによって変更されていないソリューション (ビジュアル スタジオ) 内のファイルを見ていますDebug

于 2013-10-05T17:39:35.733 に答える