基于服务的数据库.MDF

时间:2013-01-06 13:02:15

标签: c# database windows winforms

我需要存储由C#窗体应用生成的数据。我使用基于服务的数据库,我创建了我需要的表,然后我使用linq在这些表中插入值。我实际上是通过使用它来保存我的数据,经过调试我发现所有的数据都被删除了。我找不到我在运行时给出的值。任何人都可以帮我解决吗?我需要一个本地数据库来保存我的数据,我正在创建win form app,它在我的客户端系统中不使用SQL SERVER。

3 个答案:

答案 0 :(得分:2)

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

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

我认为真正的解决方案将是

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

  2. 安装SQL Server Management Studio Express

  3. SSMS Express 中创建数据库,为其指定一个逻辑名称(例如YourDatabase

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

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

    其他所有内容都完全与以前相同......

答案 1 :(得分:0)

我经历过与此相似的事情,可能也是如此。使用\bin\Debug\时,数据库的副本将保存在Data Source=|DataDirectory|\mydatabase.mdf中。在调试模式下,您的数据将保存到此副本。

如果您提供数据库文件的完整路径,则可以解决此问题,例如C:\ xxxx \ yyy \ mydatabase.mdf不可移植。希望这是你想要的?

答案 2 :(得分:0)

  1. 在App.Config文件中,更改本地数据库路径的路径

    connectionString ="数据源=(LocalDB)\ v11.0; AttachDbFilename = C:\ Users \ Gerry \ documents \ visual studio 2013 \ Projects \ DatabaseLocalApplication \ DatabaseLocalApplication \ Customers。 mdf;综合安全性=真"

  2. 这会将保存操作定向到正确的数据库。您可以通过单击数据库并复制完整路径属性

    中的条目来获取此字符串

    然后将数据库的“复制到输出目录”设置为不复制