在我的
Windows应用商店应用中,我想将现有数据库复制到存储文件夹.
我的数据库放在项目的主文件夹中.
对于复制数据表到存储文件夹,我使用以下代码(link to article):
StorageFile databaseFile = await Package.Current.InstalledLocation.GetFileAsync("people.sqlite");
await databaseFile.CopyAsync(ApplicationData.Current.LocalFolder);
在调试模式下,VS的所有功能都很棒.
但是,如果我使用发布模式或只是停止调试并从Windows打开我的应用程序 – 它不起作用.也没有抛出异常.应用程序只是在尝试调用CopyAsync时冻结.我确定,我的databaseFile!=在发布模式下也是null.
我还试图得到这样的文件:
var uri = new Uri("ms-appx:///people.sqlite");
var file = await StorageFile.GetFileFromApplicationUriAsync(uri);
但它并没有解决我的问题.
问题:将现有数据库复制到存储文件夹的正确方法是什么?
更新:
谢谢你们的答案,但我无法解决我的问题(
我使用CaliburnMicro实现MVVM.
在我的视图模型页面加载时我调用:
private async Task PrepareDatabase()
{
bool isDatabaseExisting;
var storageFolder = ApplicationData.Current.LocalFolder; ;
try
{
await storageFolder.GetFileAsync("database_name.sqlite");
isDatabaseExisting = true;
}
catch
{
isDatabaseExisting = false;
}
if (!isDatabaseExisting)
{
StorageFile databaseFile = await Package.Current.InstalledLocation.GetFileAsync("database_name.sqlite");
await databaseFile.CopyAsync(ApplicationData.Current.LocalFolder);
}
}
我的数据库:
名称 – database_name.sqlite;建立行动 – 内容;复制到输出目录 – 始终复制;
当我从visual studio启动应用程序时 – 所有工作都应该如此.
然后我停止调试,并从Windows运行应用程序 – 它冻结,当它尝试打开此页面时.