首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >|DataDirectory| 解决Web.config中数据库连接的相对路径问题

|DataDirectory| 解决Web.config中数据库连接的相对路径问题

作者头像
GoodTime
发布2024-03-05 16:13:56
发布2024-03-05 16:13:56
33000
代码可运行
举报
运行总次数:0
代码可运行

1、业务背景

维护老系统代码,Web.config中数据库字符串连接的相对路径的处理

2、核心代码如下

代码语言:javascript
代码运行次数:0
运行
复制
<connectionStrings>
    <add name="connString" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\FnDB.mdb" providerName="System.Data.OleDb"/>
</connectionStrings>

|DataDirectory|会被自动解析到App_Data

官方文档地址:对 |DataDirectory| 替代字符串和 Web 应用程序根目录运算符 (~) 的支持

3、注意事项

1)|DataDirectory| 仅能应指定在路径的开头,放在任何其他位置将得不到解析。 如 |DataDirectory|\FnDB.mdf被解析为 项目根目录\App_Data\FnDB.mdf,而\data\|DataDirectory| \FnDB.mdf 则视为物理路径,不会对|DataDirectory|做解析)

2)|DataDirectory| 在WebForm项目下默认为 项目根目录\App_Data文件夹,在Winform和控制台项目下,则为 项目根目录\bin\debug 或 项目根目录\bin\release 文件夹

对于Winform和控制台项目,一般使用AppDomain.CurrentDomain辅助类,即可以通过AppDomain.CurrentDomain.setData("DataDirectory","个人目录字符串") 来自定义|DataDirectory|的对应路径,接着去除掉debug模式和release模式的路径不同之处。此处需要注意的是,发布程序的时候,数据库也要放到App_Data目录下面,示例代码如下:

代码语言:javascript
代码运行次数:0
运行
复制
static void Main(string[] args) 
{
    string catalogue = AppDomain.CurrentDomain.BaseDirectory;
    if (catalogue.IndexOf("\\bin\\") > 0) {
        if (catalogue.EndsWith("\\bin\\Debug\\"))
            catalogue = catalogue.Replace("\\bin\\Debug", "");
        if (catalogue.EndsWith("\\bin\\Release\\"))
            catalogue = catalogue.Replace("\\bin\\Release", "");
    }
    if (!catalogue.EndsWith("App_Data\\"))
        catalogue = catalogue + "App_Data\\";
    AppDomain.CurrentDomain.SetData("DataDirectory", catalogue);
}

亦或者如下代码:

代码语言:javascript
代码运行次数:0
运行
复制
static void Main(string[] args) {
    string catalogue = AppDomain.CurrentDomain.BaseDirectory;
    if(catalogue.EndsWith(@"\bin\Debug\") || catalogue.EndsWith(@"\bin\Release\"))
    {
        catalogue =  System.IO.Directory.GetParent(catalogue).Parent.Parent.FullName  +  "\\App_Data";  
        AppDomain.CurrentDomain.SetData("DataDirectory", catalogue);    
    }
}

数据库连接配置文件与本项目Web.config配置完全相同,注意在WinForm中并不存在App_Data文件夹这个特殊文件夹,我们只需新建文件夹改名为App_Data,然后将数据库文件放入该文件夹即可。

若本文有帮助到阅读本文的同学,欢迎点赞、关注、收藏,互相学习交流。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-06-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、业务背景
  • 2、核心代码如下
  • 3、注意事项
    • 若本文有帮助到阅读本文的同学,欢迎点赞、关注、收藏,互相学习交流。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档