我在使用 Visual Studio 2010 时遇到问题。我正在使用基于服务的数据库 ( .mdf
)。问题是我可以从数据库中获取信息,但我无法将信息插入数据库。
当我向数据库添加信息时,行会受到影响,但是当我在 Visual Studios Server Explorer 中打开表时,什么都没有改变。
我编写的代码没有任何问题,因为它可以在我学校的计算机上运行。
有什么我必须更改的设置吗?
我在使用 Visual Studio 2010 时遇到问题。我正在使用基于服务的数据库 ( .mdf
)。问题是我可以从数据库中获取信息,但我无法将信息插入数据库。
当我向数据库添加信息时,行会受到影响,但是当我在 Visual Studios Server Explorer 中打开表时,什么都没有改变。
我编写的代码没有任何问题,因为它可以在我学校的计算机上运行。
有什么我必须更改的设置吗?
最有可能的是,您AttachDbFileName=......
在连接字符串中使用 - 对吗?
整个User Instance 和 AttachDbFileName=方法是有缺陷的 - 充其量!在 Visual Studio 中运行您的应用程序时,它将围绕.mdf
文件进行复制(从您的App_Data
目录到输出目录 - 通常.\bin\debug
是您的应用程序运行的位置),并且很可能,您的INSERT
工作正常 - 但您只是看错了 . mdf文件到底!
如果您想坚持使用这种方法,请尝试在myConnection.Close()
调用上设置断点 - 然后.mdf
使用 SQL Server Mgmt Studio Express 检查文件 - 我几乎可以肯定您的数据在那里。
我认为真正的解决方案是
安装 SQL Server Express(反正你已经完成了)
安装 SQL Server Management Studio Express
在SSMS Express中创建您的数据库,给它一个逻辑名称(例如YourDatabase
)
使用它的逻辑数据库名称(在服务器上创建它时给出)连接到它——不要乱用物理数据库文件和用户实例。在这种情况下,您的连接字符串将类似于:
Data Source=.\\SQLEXPRESS;Database=YourDatabase;Integrated Security=True
其他一切都和以前完全一样......