介绍
opengauss-driver是纯仓颉语言实现的 openGauss 和 PostgreSQL 数据库驱动。
软件架构
前后端通信协议模块 : proto3
前后端连接管理模块: pgconn
驱动接口实现模块: driver
简单数据库连接池模块: sqlpool
使用说明
先使用data目录里面的sql文件创建样例表
from opengauss import driver.*
from std import database.sql.*
func do_insert(db: Datasource): Unit {
let cn = db.connect()
let sql =
#"INSERT INTO "some_types" ("created_at","updated_at","deleted_at","source") VALUES ('2022-12-29 11:02:25.566','2022-12-29 11:02:25.566',NULL,'Dec 15 11:02:25') RETURNING "id""#
try (st = cn.prepareStmt(sql)) {
if (let Update(ur) = st.execute()) {
logger.debug("${ur.rowCount}, ${ur.lastInsertId}")
}
} catch (e: Exception) {
logger.error(e.message)
e.printStackTrace()
}
}
func do_query_single(db: Datasource): Unit {
let cn = db.connect()
let sql = "SELECT * FROM public.change_logs ORDER BY id ASC"
try (st = cn.prepareStmt(sql)) {
if (let Query(qr) = st.execute()) {
while (qr.next()) {
logger.debug(
"${qr.getString(0)} ${qr.getTime(1)} ${qr.getString(2)} ${qr.getString(3)} ${qr.getString(6)}")
}
qr.close()
}
} catch (e: Exception) {
logger.debug("exception ${e.message}")
e.printStackTrace()
}
}
func test_og(): Unit {
var url = "opengauss://gorm:pass@7.212.133.32:5432/loggable?sslmode=disable"
let db = sqlpool.openDb("opengauss", url)
let p = db.ping()
println("ping opengauss OK.")
do_insert(db)
do_query_single(db)
}
func test_pg(): Unit {
logger.level = LogLevel.DEBUG
var url = "postgres://gorm:pass@127.0.0.1:5432/loggable?sslmode=disable"
let db = sqlpool.openDb("postgres", url)
let p = db.ping()
println("ping postgres OK.")
do_insert(db)
do_query_single(db)
}
main() {
test_og()
test_pg()
}
为了能让大家更好的学习鸿蒙(HarmonyOS NEXT)全栈开发技术,这边特意整理了《鸿蒙开发学习手册》(共计890页)+《OpenHarmony 嵌入式开发学习手册》,希望对大家有所帮助:https://qr21.cn/FV7h05
《鸿蒙开发学习手册》:
如何快速入门:https://qr21.cn/FV7h05
- 基本概念
- 构建第一个ArkTS应用
- ……
开发基础知识:https://qr21.cn/FV7h05
- 应用基础知识
- 配置文件
- 应用数据管理
- 应用安全管理
- 应用隐私保护
- 三方应用调用管控机制
- 资源分类与访问
- 学习ArkTS语言
- ……
基于ArkTS 开发:https://qr21.cn/FV7h05
- Ability开发
- UI开发
- 公共事件与通知
- 窗口管理
- 媒体
- 安全
- 网络与链接
- 电话服务
- 数据管理
- 后台任务(Background Task)管理
- 设备管理
- 设备使用信息统计
- DFX
- 国际化开发
- 折叠屏系列
- ……
鸿蒙开发面试大盘集篇(共计319页):https://qr18.cn/F781PH
1.项目开发必备面试题
2.性能优化方向
3.架构方向
4.鸿蒙开发系统底层方向
5.鸿蒙音视频开发方向
6.鸿蒙车载开发方向
7.鸿蒙南向开发方向