HarmonyOS--数据持久化--关系型数据库

文档中心

关系型数据库

场景介绍

关系型数据库基于SQLite组件,适用于存储包含复杂关系数据的场景,比如一个班级的学生信息,需要包括姓名、学号、各科成绩等,又或者公司的雇员信息,需要包括姓名、工号、职位等,由于数据之间有较强的对应关系,复杂程度比键值型数据更高,此时需要使用关系型数据库来持久化保存数据。

约束限制

1、系统默认日志方式是WAL(Write Ahead Log)模式,系统默认落盘方式是FULL模式。

2、数据库中有4个读连接和1个写连接,线程获取到空闲读连接时,即可进行读取操作。当没有空闲读连接且有空闲写连接时,会将写连接当做读连接来使用。

3、为保证数据的准确性,数据库同一时间只能支持一个写操作。

4、当应用被卸载完成后,设备上的相关数据库文件及临时文件会被自动清除。

5、ArkTS侧支持的基本数据类型:number、string、二进制类型数据、boolean。

6、为保证插入并读取数据成功,建议一条数据不要超过2M。超出该大小,插入成功,读取失败。

运作机制

关系型数据库对应用提供通用的操作接口,底层使用SQLite作为持久化存储引擎,支持SQLite具有的数据库特性,包括但不限于事务、索引、视图、触发器、外键、参数化查询和预编译SQL语句。

接口说明

1、获得一个相关的RdbStore,操作关系型数据库,用户可以根据自己的需求配置RdbStore的参数,然后通过RdbStore调用相关接口可以执行相关的数据操作。

getRdbStore(context: Context, config: StoreConfig, callback: AsyncCallback<RdbStore>): void

参数

context:上下文

config:数据库的配置

callback:获得数据库后的回调,成功会有一个数据库store的返回

config参数的设置

javascript 复制代码
const STORE_CONFIG :relationalStore.StoreConfig= {
      name: 'RdbTest.db', // 数据库文件名
      securityLevel: relationalStore.SecurityLevel.S1, // 数据库安全级别
      encrypt: false, // 可选参数,指定数据库是否加密,默认不加密
      dataGroupId: 'dataGroupID', // 可选参数,仅可在Stage模型下使用,表示为应用组ID,需要向应用市场获取。指定在此Id对应的沙箱路径下创建实例,当此参数不填时,默认在本应用沙箱目录下创建。
      customDir: 'customDir/subCustomDir' // 可选参数,数据库自定义路径。数据库将在如下的目录结构中被创建:context.databaseDir + '/rdb/' + customDir,其中context.databaseDir是应用沙箱对应的路径,'/rdb/'表示创建的是关系型数据库,customDir表示自定义的路径。当此参数不填时,默认在本应用沙箱目录下创建RdbStore实例。
    };

调用者:relationalStore

2、执行包含指定参数但不返回值的SQL语句。

executeSql(sql: string, bindArgs: Array<ValueType>, callback: AsyncCallback<void>):void

参数

sql:执行一段sql代码,生成一个数据表

调用者:store

3、向目标表中插入一行数据。

insert(table: string, values: ValuesBucket, callback: AsyncCallback<number>):void

参数

table:数据表名字

values:插入数据

AsyncCallback:插入后的回调

调用者:store

4、根据RdbPredicates的指定实例对象更新数据库中的数据。

update(values: ValuesBucket, predicates: RdbPredicates, callback: AsyncCallback<number>):void

参数:

values:需要更新成的数据

predicates:匹配到需要更新的数据

callback:更新后的回调

调用者:store

5、根据RdbPredicates的指定实例对象从数据库中删除数据。

delete(predicates: RdbPredicates, callback: AsyncCallback<number>):void

predicates:删除找到的某条数据

callback:删除后的回调

调用者:store

6、根据指定条件查询数据库中的数据。

query(predicates: RdbPredicates, columns: Array<string>, callback: AsyncCallback<ResultSet>):void

参数:

predicates:查询的限定

columns:限定固定列的查询

callback:查询结果

调用者:store

7、删除数据库。

deleteRdbStore(context: Context, name: string, callback: AsyncCallback<void>): void

参数:

context:当前上下文

name:要删除的数据库名字

callback;删除回调

调用者:relationalStore

相关推荐
JSON_L38 分钟前
Fastadmin中实现敏感词管理
数据库·php·fastadmin
不是起点的终点2 小时前
【实战】Python 一键生成数据库说明文档(对接阿里云百炼 AI,输出 Word 格式)
数据库·python·阿里云
2301_813599554 小时前
Go语言怎么做秒杀系统_Go语言秒杀系统实战教程【实用】
jvm·数据库·python
NCIN EXPE8 小时前
redis 使用
数据库·redis·缓存
MongoDB 数据平台8 小时前
为编码代理引入 MongoDB 代理技能和插件
数据库·mongodb
极客on之路8 小时前
mysql explain type 各个字段解释
数据库·mysql
代码雕刻家8 小时前
MySQL与SQL Server的基本指令
数据库·mysql·sqlserver
lThE ANDE8 小时前
开启mysql的binlog日志
数据库·mysql
yejqvow129 小时前
CSS如何控制placeholder文字的颜色_使用--placeholder伪元素
jvm·数据库·python
oLLI PILO9 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库