ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2019-11-21 15:09:51  阅读:280  来源: 互联网

标签:sqlite win-universal-app windows-runtime windows-8-1 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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有