gpt4 book ai didi

c# - 引用和读取 .sqlite 数据库文件 (C#/UWP)

转载 作者:行者123 更新时间:2023-12-02 06:42:43 26 4
gpt4 key购买 nike

我想做的就是使用我存储在应用程序的 Assets 文件夹中的 .sqlite 数据库文件 (/Assets/CommonCore.sqlite)。我正在尝试建立连接,并且尝试了一些不同的操作:

    SQLite.Net.SQLiteConnection conn;

public MainPage()
{
this.InitializeComponent();

conn = new SQLite.Net.SQLiteConnection("Data Source=Assets/CommonCore.sqlite");

但这会引发异常“不包含采用 1 个参数的构造函数”。

    string path;
SQLite.Net.SQLiteConnection conn;

public MainPage()
{
this.InitializeComponent();

path = Path.Combine(Windows.Storage.ApplicationData.Current.LocalFolder.Path, "CommonCore.sqlite");

conn = new SQLite.Net.SQLiteConnection(new SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), path);

但它引用了文件夹“\AppData\Local\Packages\8ed84aca-896d-4286-ba91-e52316db2e89_dzc2ymb8n4xk4\LocalState\CommonCore.sqlite”,这显然不是我需要的文件。

我确信我错过了一些愚蠢的事情。

最佳答案

在 UWP 应用中,您可以访问的文件夹是有限的:

  • 用户使用 FileOpenPicker 或 FolderPicker 指定的所有文件
  • FutureAccessList 或 MostRecentlyUsedList 中的文件。 FutureAccessList 可以在 list 文件(例如文档、图片、视频文件夹)中声明。但是,用户必须允许访问这些文件夹。
  • 通过文件扩展名关联或通过共享打开的文件。
  • 应用程序安装目录。
  • 应用程序数据位置。
  • 在某些情况下可移动设备。

Source

在您的情况下,您试图写入应用程序数据位置。但是,每次安装应用程序时,此文件夹都是空的。

另一种方法是从安装文件夹中读取 sqlite 数据库。将项目中的文件添加到此文件夹很容易。为此,您首先必须声明要打包哪些文件。这意味着将它们添加到安装文件夹中。首先,在工作目录中创建一个子文件夹(您可以在其中找到 AppxManifest.xml 的文件夹)。这不是必需的,但更干净。我将我的文件夹命名为“数据”。

接下来您可以检查您是否正确执行了此操作。在 Visual Studio 中打开您的项目,然后单击解决方案资源管理器中的“显示所有文件”按钮。

'Show all files' button

之后,您应该能够在解决方案资源管理器中看到新文件夹及其内容。您现在可以右键单击该文件夹并选择“包含在项目中”。

Include in project

最后,您应该打开文件的属性(例如数据文件夹中的 db.sqlite)并将构建操作设置为内容。

Set content

现在您可以使用以下代码连接到数据库:

public class Database
{
string path;
SQLite.Net.SQLiteConnection conn;

public Database()
{
path = Path.Combine(Windows.ApplicationModel.Package.Current.InstalledLocation.Path, "Data", "Questions.sqlite");
conn = new SQLite.Net.SQLiteConnection(new
SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), path);
}
}

关于c# - 引用和读取 .sqlite 数据库文件 (C#/UWP),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35229172/

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