【仓颉三方库】 数据库驱动——opengauss-driver

192 阅读1分钟

介绍

opengauss-driver是纯仓颉语言实现的 openGauss 和 PostgreSQL 数据库驱动。

软件架构

前后端通信协议模块: proto3

前后端连接管理模块: pgconn

驱动接口实现模块: driver

简单数据库连接池模块: sqlpool

DD一下:欢迎大家关注公众号<程序猿百晓生>,可以了解到以下知识点。

`欢迎大家关注公众号<程序猿百晓生>,可以了解到以下知识点。`
1.OpenHarmony开发基础
2.OpenHarmony北向开发环境搭建
3.鸿蒙南向开发环境的搭建
4.鸿蒙生态应用开发白皮书V2.0 & V3.0
5.鸿蒙开发面试真题(含参考答案) 
6.TypeScript入门学习手册
7.OpenHarmony 经典面试题(含参考答案)
8.OpenHarmony设备开发入门【最新版】
9.沉浸式剖析OpenHarmony源代码
10.系统定制指南
11.【OpenHarmony】Uboot 驱动加载流程
12.OpenHarmony构建系统--GN与子系统、部件、模块详解
13.ohos开机init启动流程
14.鸿蒙版性能优化指南
.......

使用说明

先使用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()
}