c# mysql 文件存储_c# – 将现有数据库(存储文件)复制到存储文件夹

在Windows应用商店应用中,开发者遇到一个问题:在调试模式下能成功将SQLite数据库复制到本地存储,但在发布模式或直接运行应用时会冻结。尝试使用`Package.Current.InstalledLocation.GetFileAsync`和`StorageFile.GetFileFromApplicationUriAsync`方法均未解决问题。更新提到使用CaliburnMicro的MVVM架构,并在ViewModel的页面加载时进行数据库复制,但仍然在运行应用时出现冻结情况。
摘要由CSDN通过智能技术生成

在我的

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运行应用程序 – 它冻结,当它尝试打开此页面时.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值