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

介绍

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

  1. 基本概念
  2. 构建第一个ArkTS应用
  3. ……

开发基础知识:https://qr21.cn/FV7h05

  1. 应用基础知识
  2. 配置文件
  3. 应用数据管理
  4. 应用安全管理
  5. 应用隐私保护
  6. 三方应用调用管控机制
  7. 资源分类与访问
  8. 学习ArkTS语言
  9. ……

基于ArkTS 开发:https://qr21.cn/FV7h05

  1. Ability开发
  2. UI开发
  3. 公共事件与通知
  4. 窗口管理
  5. 媒体
  6. 安全
  7. 网络与链接
  8. 电话服务
  9. 数据管理
  10. 后台任务(Background Task)管理
  11. 设备管理
  12. 设备使用信息统计
  13. DFX
  14. 国际化开发
  15. 折叠屏系列
  16. ……

鸿蒙开发面试大盘集篇(共计319页):https://qr18.cn/F781PH

1.项目开发必备面试题
2.性能优化方向
3.架构方向
4.鸿蒙开发系统底层方向
5.鸿蒙音视频开发方向
6.鸿蒙车载开发方向
7.鸿蒙南向开发方向

《OpenHarmony 嵌入式开发学习手册》:https://qr18.cn/F781PH

在这里插入图片描述

CJK仓颉输入法数据库是指为仓颉输入法提供收录和管理汉字字符及其相应输入码的数据库仓颉输入法是一种用于输入中文字符的输入法,它采用了古代汉字字形和笔画的组合规则来生成每个汉字的输入码。输入码是指在键盘上输入的一组字符以唤出对应的汉字。 CJK是指"Chinese, Japanese, Korean" 的缩写,表示支持中日韩三国语言的输入法系统。因为中文输入码的设计能够应用于这三个语言,所以CJK仓颉输入法数据库也用于日语和韩语的输入。 仓颉输入法数据库包含了大量的汉字和其对应的输入码数据。这些数据可以根据仓颉输入法的规则和要求进行生成和维护。数据库中的每个汉字都对应一个输入码,通过输入码的组合方式可以准确地输入出所需的汉字。数据库的管理者会不断收录和更新汉字及其输入码,确保数据库的完整性和实用性。 仓颉输入法数据库的作用非常重要。它是仓颉输入法正常运作的基础,决定了仓颉输入法用户能够输入哪些汉字。数据库中的数据还会随着时间的推移不断增加和完善,以适应新的汉字的加入和使用需求的变化。 总之,CJK仓颉输入法数据库是一个为仓颉输入法提供汉字和输入码数据的数据库,对于保证仓颉输入法的准确性和实用性起到了重要作用。通过合理的管理和维护,该数据库能够为用户提供全面且准确的中文输入服务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值