网站地图 | 联系我们 | 咨询热线:13999201770
您现在的位置: 新疆二域设计网络公司 >> 网页设计学院 >> 网络编程 >> NET编程 >> 正文

好多朋友被ACCESS数据库在.net程序中相对路径的问题困扰,搞得每次移动程序都要去修改web.config
中数据库连接字符串的数据库路径。

好多人的web.config中的写法如下:

<appSettings>
<add key="OLEDBCONNECTIONSTRING" value="Provider=Microsoft.Jet.OLEDB.4.0;Data
Source=E:\web\App_Data\Data.mdb)"></add>
</appSettings>

程序中这样写:

MyConn = new OleDbConnection(System.Configuration.ConfigurationManager.AppSettings["OLEDBCONNECTIONSTRING"]);//注释一下:VS2005和VS2003中的ConfigurationSettings写法不一样,具体区别自己查吧

这样程序运行时经常提示诸如以下的错误:
'C:\WINDOWS\system32\~\App_Data\Data.mdb'不是一个有效的路径。 确定路径名称拼写是否正确,以及是否连接到文件存放的服务器。 Data Source=~\App_Data\Data.mdb
就算用绝对路径正确,那么移植程序时还要去修改web.config,所以比较麻烦。

也有在web.config中使用象ASP那样的Server.MapPath取数据库路径的,但web.config不认识Server.MapPath,此方法也行不通。

后来通过摸索、参考其它程序,总结出如下方法,可以方便的移植程序路径而不必再去修改ACCESS数据库路径。

我在web.config中的写法如下:

<appSettings>
<add key="SQLConnString" value="provider=microsoft.jet.oledb.4.0;data source="/>
<add key="dbPath" value="~/App_Data/mydata.mdb"/>
</appSettings>
程序中的数据访问类中我把"SQLConnString"和"dbPath"取出来连接成一个字符串"CONN_STRING_NON_DTC"
public static readonly string CONN_STRING_NON_DTC = System.Configuration.ConfigurationManager.AppSettings["SQLConnString"].ToString() + System.Web.HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["dbPath"]) + ";";
这是VS2005中的写法
我把CONN_STRING_NON_DTC定义成static readonly是为了使用方便。
好了,这样就可以随便移植你的程序而不用关心数据库的路径了,一劳永逸啊^_^,适合我这样的懒人!

作者:佚名 | 文章来源:不详 | 更新时间:2007-5-4 11:12:27

  • 上一篇文章:

  • 下一篇文章:
  • 相关文章:
    保存对共享Access数据库的设计更改
    .NET程序编译错误类型系统找不到 Microsoft.Office.Interop.Word…
    ASP.NET生成静态页面和分页
    ASP.NET+Ajax 1.0框架开发幻灯片播放网页…
    ASP.NET+Access环境下的数据库安全问题
    Access数据库体积过大问题的几种解决方案
    在 ASP.NET 中用匿名委托简单模拟 AOP 做异常和日志处理…
    在ASP.NET页面上轻松整合javascript
    在ASP.NET中如何防范SQL注入式攻击
    用C#访问ACCESS数据库问题

    色彩理念
    网页制作
    美工图形
    网络编程
    数 据 库
    网站运营
    ::最近更新::
    ·在ASP.NET AJAX中防止用户…
    ·使用PostSharp进行AOP框架…
    ·AnimationExtender控件的动…
    ·ASP.NET 2.0中客户端脚本使…
    ·正则表达式初级知识
    ·.NET之对接口和抽象类
    ·.NET程序编译错误类型系统…
    ·ASP.NET生成静态页面和分页
    ·asp.net ajax 无法弹出ale…
    ·asp.net Ajax---Validator…
    ·从.Net类库代码来看Asp.ne…
    ·向Asp.net Ajax 传入DateT…
    ·Ajax中动态执行返回到inne…
    ·在建立了聚集索引的表内 数…
    ·基于ASP.NET AJAX技术开发…
    ::推荐阅读::
    ·用C#对DBF数据库的操作
    ·如何建立自己的新闻发布系…
    ·用C#访问ACCESS数据库问题
    ·ASP.NET技巧:脚本获取选中…
    ·Asp.Net小技巧之在client端…
    ·ASP.NET入门数据篇

    关于我们 | 网站建设 | 服务帮助 | 联系我们 | 网页设计学院 | 实用工具 | 友情链接 | 新疆专题
    版权所有 © 2007 新疆二域设计网络公司 www.xjcncn.com All Rights Reserved
    网站建设总机:0991-4811639 传真:0991-4842803 ;咨询热线:13999201770. E-mail:xjcncn@gmail.com
    MSN :xjcncn@hotmail.com ; QQ:359312 ;地址:新疆乌鲁木齐市友好E时代公寓B座708 邮编:830000