attempt to write a readonly database hbuilder 5+api 引入sqlite的.db文件 只能读不能写的解决办法

attempt to write a readonly database hbuilder 5+api 引入sqlite的.db文件 只能读不能写的解决办法

问题简介

database放入建好表结构的local.db后,在pages的HTML中可以通过…/database/local.db进行读取,但无法进行update,insert等写操作,也就是此目录下的文件只能读不能写。

在这里插入图片描述

解决方法

将database中的local.db复制到可读写的文件夹即可
通过https://www.html5plus.org/doc/zh_cn/io.html可知,downloads文件夹是可行的
操作步骤
首先修改runmode为liberate,不然后面的代码只有调试的时候生效,打包后无效
在这里插入图片描述
然后在合适的地方添加以下代码,判断文件是否存在,不存在就复制过去,复制到可以读写的目录plus.io.resolveLocalFileSystemURL需要嵌套使用,具体原因我也不清楚。

		mui.plusReady(function(){
   
			plus.io.resolveLocalFileSystemURL('_downloads/local.db',
			res=>{
   //文件存在
				console.log('已存在')
			},error=>{
   
				plus.io.resolveLocalFileSystemURL('/database/local.db',res1=>{
   
					plus.io.resolveLocalFileSystemURL('_downloads/',res2=>{
   
						res1.copyTo(res2,'local.db',entry=>{
   
							console.log('复制成功')
						},e=>{
   
							alert
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值