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