HarmonyOS Next 入门实战 - 关系型数据库、smartdb
SQLite数据库
HarmonyOS的关系型数据库基于SQLite
导入模块
import { relationalStore } from '@kit.ArkData';
实现步骤:
- 获取RdbStore对象,用于创建数据库,数据表,以及数据库升级等操作
let storeConfig = {
name: 'Poetry.db', //数据库文件名
securityLevel: relationalStore.SecurityLevel.S1, //安全级别
encrypt: false, //是否加密,可选,默认不加密
customDir: '', //自定义路径,可选,目录:context.databaseDir + '/rdb/' + customDir
isReadOnly: false, //是否已只读方式打开,可选,默认false
}
relationalStore.getRdbStore(this.context, this.storeConfig)
.then(store => {
//创建表
store.executeSql('sql')
//判断版本
store.version
})
.catch((err: Error) => {
})
- 插入数据
let data :ValuesBucket={
name:"zhangsan",
age: 23,
}
store.insert("tableName",data).then((rowId)=>{
//操作成功返回rowId,否则返回-1
})
store.batchInsert() //用于插入批量数据
- 修改,删除数据:通过组件提供的谓词(Predicates)修改或删除组件
let data :ValuesBucket={
name:"zhangsan",
age: 26,
}
let predicates = new relationalStore.RdbPredicates("tableName")
predicates.equalTo("name","zhangsan")
//更新数据
store.update(data,predicates).then((value)=>{
})
//删除数据
store.delete(predicates).then((value)=>{
})
- 查询数据
let predicates = new relationalStore.RdbPredicates("tableName")
predicates.equalTo("name","zhangsan")
store.query(predicates).then((resultSet)=>{
while (resultSet.goToNextRow()){
const name = resultSet.getString(resultSet.getColumnIndex("name"))
const age = resultSet.getLong(resultSet.getColumnIndex("age"))
}
resultSet.close()
})
//也可以通过下面接口使用sql查询
store.querySql(sql: string, bindArgs?: Array<ValueType>): Promise<ResultSet>;
- 备份数据和恢复数据
//备份数据
store.backup("backup.db")
//恢复数据
store.restore("backup.db")
SmartDB
SmartDB与Android中的room组件类似,可以简化我们数据库操作的步骤,使代码更易维护。
安装和导入模块
//安装模块
ohpm install @liushengyi/smartdb
//导入模块
import sql from "@liushengyi/smartdb"
定义数据结构:
export class Poetry {
@sql.SqlColumn(sql.ColumnType.TEXT)
uuid?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
title?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
dynasty?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
author?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
introduction?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
text?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
textAlign?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
translation?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
rectify?: string
@sql.SqlColumn(sql.ColumnType.TEXT)
searchKey?: string
}
执行数据库操作:进行增删改查、事务操作
export class PoetryDao {
public static TABLE_NAME = "Poetry"
public static SQL_CREATE_TABLE =
"CREATE TABLE IF NOT EXISTS `Poetry` (`uuid` TEXT NOT NULL, `title` TEXT, `dynasty` TEXT, `author` TEXT, `introduction` TEXT, `text` TEXT, `textAlign` TEXT, `translation` TEXT, `rectify` TEXT, `searchKey` TEXT, PRIMARY KEY(`uuid`))"
@sql.SqlQuery(`select * from ${PoetryDao.TABLE_NAME} where uuid=#{uuid}`)
@sql.ReturnType(Poetry)
queryOne(@sql.Param('uuid') uuid: string): Promise<Poetry> {
return sql.PromiseNull()
}
@sql.SqlQuery(`select count(*) from ${PoetryDao.TABLE_NAME} `)
@sql.ReturnType(Number)
queryCount(): Promise<Number> {
return sql.PromiseNull()
}
@sql.SqlInsert(`insert into ${PoetryDao.TABLE_NAME} values (#{data.uuid},#{data.title},#{data.dynasty},#{data.author},#{data.introduction},#{data.text},#{data.textAlign},#{data.translation},#{data.rectify},#{data.searchKey})`)
insert(@sql.Param('data') data: Poetry): Promise<void> {
return sql.PromiseNull()
}
@sql.Transactional()
async insertPoetryAll(list: Poetry[]) {
for (let item of list) {
await this.insert(item)
}
}
}
数据库管理:创建数据库、数据库升级
export class DatabaseManager {
static readonly DATABASE_VERSION = 1
static readonly DATABASE_NAME = 'poetry.db'
static init(context: Context) {
sql.dbHelper.initDb(context,
DatabaseManager.DATABASE_NAME,
DatabaseManager.DATABASE_VERSION,
new DbOpenHelperImpl()
)
}
}
class DbOpenHelperImpl extends sql.DbOpenHelper {
//创建数据库
onCreate(db: relationalStore.RdbStore): void {
db.executeSql(PoetryDao.SQL_CREATE_TABLE)
}
//升级数据
onUpgrade(db: relationalStore.RdbStore, oldVersion: number, newVersion: number): void {
}
}
最后在app启动的时候调用初始化方法
export default class EntryAbility extends UIAbility {
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');
DatabaseManager.init(this.context)
}
}
数据初始化和使用
将json格式的数据插入到数据库中
poetryDao: PoetryDao = new PoetryDao()
new Promise<boolean>(async (resolve, reject) => {
try {
let count = await this.poetryDao.queryCount()
if (!count) {
let list = await (await import("resources/rawfile/poetry.json")).default
let poetryArray: Array<Poetry> = []
for (let item of list) {
let poetry = item as Poetry
poetry.uuid = util.generateRandomUUID()
if (poetry.rectify) {
poetry.rectify = JSON.stringify(poetry.rectify)
}
poetryArray.push(poetry)
}
this.poetryDao.insertPoetryAll(poetryArray)
resolve(true)
} else {
resolve(false)
}
} catch (e) {
reject(e)
}
})
读取数据
//读取所有数据
new PoetryDao().queryList()
.then((value) => {
})
//读取一条数据
new PoetryDao().queryOne("id")
.then((value) => {
})
本文的技术设计和实现都是基于作者工作中的经验总结,如有错误,请留言指正,谢谢。
HarmonyOS Next 入门实战 - 关系型数据库、smartdb的更多相关文章
- Sqoop2入门之导入关系型数据库数据到HDFS上(sqoop2-1.99.4版本)
sqoop2-1.99.4和sqoop2-1.99.3版本操作略有不同:新版本中使用link代替了老版本的connection,其他使用类似. sqoop2-1.99.4环境搭建参见:Sqoop2环境 ...
- RDS关系型数据库 入门 01 创建关系型数据库实例【华为云分享】
[摘要] 关系型数据库(Relational Database Service,简称RDS)是一种基于云计算平台的即开即用.稳定可靠.弹性伸缩.便捷管理的在线关系型数据库服务.RDS具有完善的性能监控 ...
- 非关系型数据库MongoDB入门
本文分为以下四块简单介绍非关系型数据库MongoDB:1.MongoDB简介.2.MongoDB和关系数据库对比.3.MongoDB基本概念.4.mongo shell的使用以及对MongoDB的增删 ...
- MongoDB学习笔记(二:入门环境配置及与关系型数据库区别总结)
一.下载及安装MongoDB MongoDB下载官网链接:http://www.mongodb.org/downloads 具体安装步骤教程:http://www.shouce.ren/api/vie ...
- [Python3网络爬虫开发实战] 5.3-非关系型数据库存储
NoSQL,全称Not Only SQL,意为不仅仅是SQL,泛指非关系型数据库.NoSQL是基于键值对的,而且不需要经过SQL层的解析,数据之间没有耦合性,性能非常高. 非关系型数据库又可细分如下. ...
- NoSQL数据库技术实战-第1章 NoSQL的数据一致性 传统关系型数据库的ACID
在看着章节的时候,我简单的回顾了一下关系型数据库的事务处理的ACID原则,其中原子性和持久性比较好理解.由于以前没有深入去研究.关于一致性和隔离性上我产生了疑问,在整理后分析如下: 一致性:书中所 ...
- Jmeter(七) - 从入门到精通 - 建立数据库测试计划实战<MySQL数据库>(详解教程)
1.简介 在实际工作中,我们经常会听到数据库的性能和稳定性等等,这些有时候也需要测试工程师去评估和测试,上一篇文章宏哥主要介绍了jmeter连接和创建数据库测试计划的过程,宏哥在文中通过示例和代码非常 ...
- Spark入门实战系列--1.Spark及其生态圈简介
[注]该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取 .简介 1.1 Spark简介 年6月进入Apache成为孵化项目,8个月后成为Apache ...
- Spark入门实战系列--6.SparkSQL(上)--SparkSQL简介
[注]该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取 .SparkSQL的发展历程 1.1 Hive and Shark SparkSQL的前身是 ...
- JDBC+MySQL入门实战(实现CURD的例子)
前言 hello我是bigsai,今天咱们进行JDBC+MySQL实战,非常适合初入门的小伙伴打开新的世界.实现一个增删改查(curd)的例子.先点赞再观看.帅哥靓女养成好习惯! 在这个案例进行之前, ...
随机推荐
- dotnet的Lambda表达式 委托泛型(2) Action Func
// 总结:// 泛型:把类,方法,属性,字段做到了通用化// 反射:操作dll文件的一个帮助类库// 特性:就是一个特殊的类 自定义标记属性特性 他就是AOP的另一种实现方式 验证属性// 委托:就 ...
- 21 如何写出一篇高质量的sci水文
博客配套视频链接: https://www.bilibili.com/video/BV1fW4y1W7dS/ b 站直接看 模型确定, 结果正在跑(或已结束), 目标期刊已定,一般可以定顶刊 从目标期 ...
- KubeSphere 3.4.0 发布:支持 K8s v1.26
2023 年 07 月 26 日,KubeSphere 开源社区激动地向大家宣布,KubeSphere 3.4.0 正式发布! 让我们先简单回顾下之前三个大版本的主要变化: KubeSphere 3. ...
- 云原生周刊:Kubernetes v1.27 发布 | 2023.4.17
开源项目推荐 Palaemon Palaemon 是一个开源开发工具,用于监控 Kubernetes 集群的健康状况和资源指标并分析内存不足 (OOMKill) 错误. Gitkube Gitkube ...
- 自如月租计算 ziroom
前言 自如的房子月租看似不高,实际上它是收中介费的,加上中介费和未满一年的押金,房租其实非常高. 普通中介费一般收1个月,自如的中介费美名其曰服务费(除了网费想不到有什么用的),一年为1.2个月租金. ...
- 指针进阶(函数指针)(C语言)
目录 1. 字符指针变量 2. 数组指针变量 2.1 数组指针变量是什么? 2.2 数组指针变量怎么初始化? 3. 二维数组传参的本质 4. 函数指针变量 4.1 函数指针变量的创建 4.2 函数指针 ...
- 版本库控制系统的切磋之路[Git & SVN]
集中式和分布式 集中式版本库控制系统 :SVN ; 分布式版本库控制系统 :Git . 集中式 版本库是存在中央服务器的.干活使用的是自己的电脑,每次干活前都是从服务器上拉下最新的代码版本,然后才 ...
- vscode连接docker时需要为docker容器开设一个映射端口
相关: vscode远程连接远程主机上的docker -- 设置命令 -- -p 5001:5001 设置端口: -p 5001:5001 命令Demo: docker run -it -v /hom ...
- Rsync远程同步知识点总结
Rsync: 简介:是一个开源的快速备份工具.可以在不同主机之间镜像同步整个目录,支持增量备份,保持链接(硬链接.软连接)和权限,且采用优化同步算法,传输前执行压缩(传输过程中效率加快了,但是会增加c ...
- 一个专注推荐.Net开源项目的榜单
大家好,我是编程乐趣,从7月份开始推荐开源项目,已经推荐了接近100个开源项目了,其中绝大部分是有关.Net的开源项目,也受到大家非常多人的喜欢. 由于公众号不方便查询,很多人又想了解更多的开源项目, ...