gpt4 book ai didi

c# - 如何读取 |DataDirectory| 的当前路径从配置设置

转载 作者:太空狗 更新时间:2023-10-29 22:04:47 24 4
gpt4 key购买 nike

我正在编写一个程序,要求用户在应用程序启动时选择事件数据库。我有一个 Windows 窗体,它将列出存储在 ApplicationData 的子文件夹中的数据库,专门用于存储数据库文件。然而,当我创建一个新数据库时,我需要复制模板数据库,但无法弄清楚它默认存储在哪里。

我试过:

dpath = ConfigurationManager.AppSettings["DataDirectory"];

不过,我似乎总是得到一个空值作为返回。有一次我放弃了,并认为我可以将 DataDirectory 设置为我选择的文件夹,但似乎我在执行程序时为时已晚,无法生效。

newdpath = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) + "\\MyAppFolder";

如果您有任何关于如何找到数据库位置或尽早自行设置以影响程序运行的建议,我将不胜感激。

编辑:

对于第二部分,我发现我试图在执行了 TableAdapter.Fill 命令后修改连接字符串,从而解释了它打开默认数据库的原因。这个谜团已经解开了。然而,第一部分仍然是未知数。

谢谢。

最佳答案

|DataDirectory| 不是来自配置设置;你混淆了三种不同的东西:

ConfigurationManager.AppSettings["DataDirectory"]

这来自配置设置;您必须创建并放入项目中的 .config 文件。此特定设置是 AppSettings 元素中具有键 "DataDirectory" 的元素的值。除非您将其放入 .config 文件中,否则它不存在。通常这是放置永远不会更改的配置或启动数据的地方。您不应在此处放置文件路径,因为它们在用户安装数据库的计算机上可能不同。

Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData)

这是当前用户的漫游应用程序数据文件夹的路径,该文件夹由安装您的应用程序的操作系统定义。您无法更改它,它由操作系统定义。您可以确定此文件夹可由用户写入,如果用户卸载您的应用程序将不会被删除,并且如果用户漫游或从另一台计算机登录时将可用。这通常是您要放置可编辑应用程序数据的地方。

SqlConnection("Data Source=|DataDirectory|DatabaseFileName.sdf;...")

这是 ADO.NET 连接的连接字符串。 ADO.NET 对垂直条进行特殊处理,它会查找与垂直条之间的键名匹配的 AppDomain 数据。您可以获得相同的数据:

AppDomain.CurrentDomain.GetData("DataDirectory")

那么DataDirectory的值是怎么写的呢?这是通过部署您的可执行文件来完成的:

  • .MSI 安装程序将其定义为应用程序的目标文件夹。
  • ClickOnce 在您的项目中定义了一个特殊的数据文件夹。
  • Web 应用程序使用 App_Data 文件夹。
  • Visual Studio 调试器使用调试文件夹。

请注意,.MSI 安装程序可以允许用户更改 DataDirectory;这就是为什么你永远不应该硬编码或更改 DataDirectory,如果你这样做,就没有办法找到你的应用程序数据的部署位置。您通常使用 DataDirectory 文件夹来存储与可执行文件一起部署的只读二进制数据。

如果您需要写入与可执行文件一起部署的数据,您应该首先将其复制到您知道用户可以写入的某个位置,例如 Environment.SpecialFolder.ApplicationData,然后写入到副本。 DataDirectory 不仅用户不一定可写,而且它是部署的一部分,而不是用户数据的一部分;如果您修复或卸载可执行文件,则会重新安装或删除 DataDirectory。用户不喜欢您删除他们的数据,因此不要将其保存到 DataDirectory

关于c# - 如何读取 |DataDirectory| 的当前路径从配置设置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12266924/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com