HarmonyOS 鸿蒙Next关系型数据库初始化问题

发布于 1周前 作者 phonegap100 来自 鸿蒙OS

HarmonyOS 鸿蒙Next关系型数据库初始化问题

谁能救救我,做期末大作业数据库初始化不知道怎么做。我以为我初始化完成了,结果插入数据的时候报错,一个是提示视图调用未初始化的数据

cke_10585.png

这是我的项目结构,DBF是数据库的一些操作,我希望在Index(登录界面),RegistPage(注册界面),Homepage(首页)对数据库进行一些增删改查的操作

cke_11089.png

这是DBF.ts的初始化数据库的代码

cke_852.png

在index中我这样初始化,然后我发现预览器一片白,什么也看不了了

cke_1441.png

cke_26792.png

真的纯新手,很菜,希望有大佬能耐心帮忙!谢谢


更多关于HarmonyOS 鸿蒙Next关系型数据库初始化问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

5 回复

1、relationalClass 不用 extends UIAbility,数据库和UI没有直接关系,不知道你继承这个是为啥;正常模板项目在EntryAbility中已经继承 UIAbility了;

2、relationalClass 最好声明一个成员变量保存 .getRdbStore() 回调中返回的 store对象,在后续数据库操作中要用;另外最好准备个全局变量指示初始化完成否;

3、数据库初始化是异步操作,而且有延迟,因此应用启动时越早初始化越好,建议可在EntryAbility的onCreate()或onWindowStageCreate()中调用相关方法;在UI界面的aboutToAppear里可进行判断是否初始化完成;同时若未完成建议加个setInterval()循环检测此完成状态变量,为避免死循环加个3次左右不再循环,时间间隔可根据情况调整,100ms, 200ms, ...

4、创建表的SQL语句中加个 IF NOT EXISTS 在 TABLE 后面,因为每次启动应用都会运行建表操作,不能重复建表。

另外,代码中在调试期间在关键部位加些日志打印各种状态,帮助确认应用启动流程中在哪里完成了哪些操作,是否正常执行等。

5、UI问题应该在数据处理之间先调试好,无论有无数据应该能有个默认界面显示,数据和UI间用状态变量进行绑定后,数据更新自然会触发UI更新,登录注册这种简单的UI应该在初始状态下和数据无关,毕竟是没输入数据,只有交互后有了输入才会触发数据相关操作,所以先准备基本UI,然后关注数据流,中间用日志进行追踪各中间环节。

祝码运昌盛。。。。。。:)

更多关于HarmonyOS 鸿蒙Next关系型数据库初始化问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


谢谢,我研究一下

大佬!有个问题,就是说怎么在aboutToAppear里判断是否数据库是否初始化完成

声明一个全局变量,比如 isReady: boolean = false; 然后在初始化DB的异步方法回调时判断是否出错,没有则设置 isReady = true; DB初始化主要是getRdbStore(), 及 executeSql()创建表,这两个方法都有回调函数的,回调应当一层套一层进行,或者并发时进行单个操作的确认,如果是多个异步并发(比如几个表同时创建),则可准备一个boolean[]分别对应各表创建完成否进行确认,最后检查整个数组确认是否所有表完成创建,这样的思路应对异步场景下多个异步操作的完成确认。 在aboutToAppear中可调用一个检查函数,函数只要对isReady进行判断,未完成则触发setTimeOut()延时一段时间(ms)后再调用自己再次检查,通常合适的间隔时间,一两次检查就可得到完成的状态,然后就可继续进行数据库的操作,读取数据之类的。

HarmonyOS 鸿蒙Next关系型数据库初始化问题,通常涉及几个关键步骤和配置。以下是一些专业解答:

首先,确保你使用的是HarmonyOS内置的@ohos.data.relationalStore模块进行关系型数据库操作。初始化数据库时,需要配置数据库名称和安全级别,如:

const config = {
    name: 'MyApplication.db',
    securityLevel: relationalStore.SecurityLevel.S1
};

接着,使用relationalStore.getRdbStore方法获取RdbStore对象,并执行SQL语句创建表:

relationalStore.getRdbStore(context, config, (err, rdbStore) => {
    if (err) {
        console.error('获取RdbStore失败');
        return;
    }
    const sql = 'CREATE TABLE IF NOT EXISTS TASK (ID INTEGER PRIMARY KEY AUTOINCREMENT, NAME TEXT NOT NULL, FINISHED BIT)';
    rdbStore.executeSql(sql);
});

如果在初始化过程中遇到问题,请检查配置是否正确,SQL语句是否有误,以及上下文context是否已正确传递。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部