C#项目使用本地数据库的一些问题

当我们建立一个小的应用程序而并非是一个真正的项目的时候,可能经常会要把它拷贝到不同的机器上去运行,这个时候,我觉得就没必要把数据库(我这里以sqlserver为例)和程序分开单独的建立在自己的电脑上了,因为程序一动,还要拷贝数据库文件,这样一来就麻烦了。我们可以直接把数据库建立在项目里面。
    这样一来,移动项目的时候,把项目拷走,数据库文件就一起跟着走了,但是这样可能还会有一个问题,如果我们之前使用的连接字符串是直接从程序中的数据库测试连接那里面拷贝过来的话,就会出现路径不对的问题。

我以前学习ADO.NET的时候,就经常这样做。直接从这里面去拷贝。
拷贝出来的字符串是这样的:Data Source=.\SQLEXPRESS;AttachDbFilename=F:\DbConnectionTest\DbConnectionTest\TestDb.mdf;Integrated Security=True;User Instance=True
显然这里面的路径只是相对于本机来的。如果到了其它机器上,会出现问题,我们可以做如下修改:
AttachDbFilename=F:\DbConnectionTest\DbConnectionTest\TestDb.mdf;======》AttachDbFilename=|DataDirectory|\TestDb.mdf;
这里,是用|DataDirectory|代替了之前的绝对路径。如果你的程序是winform或者控制台应用程序类型的,那么DataDirectory代表的是本应用程序的debug文件夹,如果你的程序是网站,那么它就代表的是App_Data文件夹。

原文地址:https://www.cnblogs.com/La5DotNet/p/2792173.html