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/archive/2012/11/28/2792173.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值