数据库
首页 > 数据库> > c#-将现有数据库加载到通用应用程序

c#-将现有数据库加载到通用应用程序

作者:互联网

我正在尝试在Universal 8.1应用程序中加载现有数据库文件.

我安装了所有必需的软件包,并且正在使用SQLitePCL包装器.

当我尝试使用以下命令打开数据库文件时:

conn = new SQLiteConnection("test.db");

它正在创建一个新的空数据库. (我的意思是,每个SELECT命令都会失败,并且没有这样的表错误.所以这不是我的数据库,而是一个新数据库.)

也,

conn = new SQLiteConnection("ms-appx:///test.db");

抛出此异常:

Unable to open the database file: ms-appx:///test.db Details: unable to open database file

我的test.db位于Shared项目的根目录中,“构建操作”设置为“内容”,“复制到输出目录”设置为“如果较新”.

我不确定自己在做什么错.你能帮助我吗?

>如果这是一个愚蠢的问题,请接受我的歉意,我是WinRT编程的新手.

解决方法:

有一个关于sqlite-net包装器的解决方案,该解决方案也适用于SQLitePCL:http://wp.qmatteoq.com/import-an-already-existing-sqlite-database-in-a-windows-8-application/

总结是,那些包装器在LocalStorage文件夹中查找数据库.因此,您需要在访问数据库之前将文件复制到LocalStorage.

private async Task CopyDatabase()
{
    bool isDatabaseExisting = false;
 
    try
    {
        StorageFile storageFile = await ApplicationData.Current.LocalFolder.GetFileAsync("people.db");
        isDatabaseExisting = true;
    }
    catch
    {
        isDatabaseExisting = false;
    }
 
    if (!isDatabaseExisting)
    {
        StorageFile databaseFile = await Package.Current.InstalledLocation.GetFileAsync("people.db");
        await databaseFile.CopyAsync(ApplicationData.Current.LocalFolder);
    }
}

之后,可以使用以下代码行访问数据库:

conn = new SQLiteConnection("test.db");

但是,问题在于我将在手机中存储两个数据库文件实例.我不知道该怎么解决.有人可以帮忙吗?

标签:sqlite,win-universal-app,windows-runtime,windows-8-1,c
来源: https://codeday.me/bug/20191121/2052643.html