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)的例子.先点赞再观看.帅哥靓女养成好习惯! 在这个案例进行之前, ...
随机推荐
- web端ant-design-vue Modal.info组件自定义icon和title使用小节
web端ant-design-vue Modal.info组件自定义icon和title整理小节,最近在项目中用到了自定义icon和title的功能,经过测试发现,如果自定义icon title会自动 ...
- Linux利用ftp命令上传下载文件
Linux中如何使用ftp命令,包括如何连接ftp服务器,上传or下载文件以及创建文件夹.虽然现在有很多ftp桌面应用(例如:FlashFXP),但是在服务器.SSH.远程会话中掌握命令行ftp的使用 ...
- duxapp放弃了redux,在duxapp中局部、全局状态的实现方案
全局状态 全局状态是一个很实用的功能,例如管理用户信息,组件间状态共享等功能都需要用到全局状态,react有很多成熟的全局状态管理工具,但是很多写起来太过麻烦,duxapp提供了几种应对不同场景的全局 ...
- 基于CTFshow的文件上传二次渲染绕过与CTF实战
1. 二次渲染简介 二次渲染指的是上传的文件(如图片),为了显示的更加规范(尺寸.像素),网站会对文件进行二次处理,经过解码或转换可能导致其中的恶意代码失效.例如,后门程序在图像渲染过程中可能被清除或 ...
- 基于Java+SpringBoot心理测评心理测试系统功能实现九
一.前言介绍: 1.1 项目摘要 心理测评和心理测试系统在当代社会中扮演着越来越重要的角色.随着心理健康问题日益受到重视,心理测评和心理测试系统作为评估个体心理状态.诊断心理问题.制定心理治疗方案的工 ...
- pjsip编译、说明及vs2022使用示例
环境: window10_x64 & vs2022 pjsip版本: 2.14.1 之前整理过pjsip 2.10的编译及python使用示例: https://www.cnblogs.c ...
- Failed to load resoure:the serve responded with a status of 405 (Method Not Allowed)
在项目中 web.config 引入 iis 删除WEBDEV 配置结束后 重启服务器
- 超级干货:Air780E之RS485通信篇,你学会了吗?
今天,我们来学习低功耗4G模组Air780E的RS485通信,同学们,你学习了吗? 一.RS485简介 物联网(IoT)在工业场景中的应用越来越广泛,而RS485是一种常见的通信协议,广泛应用于 ...
- js中栈的运用
JavaScript 中栈的运用 在 JavaScript 中,栈(Stack)是一种非常有用的数据结构,它遵循后进先出(Last In First Out,LIFO)的原则.在本文中,我们将深入探讨 ...
- php open_basedir的使用
今天跨省问为什么file_exists检测一个相对路径的文件无法获取到true,文件明明有,但是获取不到,我看了一下,感觉可能是因为这个文件是软链接过来的有关系. 然后他找了找发现是和这么一个文件.u ...