golang访问KingbaseES V8R6

news2024/10/7 1:32:48

概述

本文介绍go语言连接KingbaseES V8R6数据库的步骤

测试环境

操作系统:CentOS 7.2.1511
数据库版本:KINGBASE (KingbaseES) V008R006C007B0012
go版本:go version go1.19.4 linux/amd64

KingbaseES go驱动获取

go连接kingbase数据库需要该数据库的go驱动,驱动位于Kingbase数据库安装目录Interface/golang子目录下:

另外,驱动版本需要与go编译运行环境版本一致,本人测试环境的go版本为:1.19.4

kingbase自带的 go驱动版本为:1.11.5
在这里插入图片描述
注意:驱动编译的go环境版本,和本地go版本不一致,后面应用go代码编译时会报错,需要换对应版本的kingbase go驱动。

go 1.19.4版本kingbase go驱动编译

用Kingbase的go驱动源码重新编译对应版本go驱动:
1、获取驱动源码包: gokb-source.tar.gz
2、解压驱动源码压缩包到当前路径:
在这里插入图片描述
源码位于解压后的kingbase.com/gokb文件夹内:

3、kingbase go驱动包含gokb.a、oid.a、scram.a 3个静态库文件需要重新编译
1)编译gokb.a
在这里插入图片描述
2)编译oid.a
在这里插入图片描述
3)编译scram.a
在这里插入图片描述

静态库形式驱动使用

1、新建drivers目录(Note: 目录名可以随便命起,编译时指定对路径即可)以及和kingbase自带驱动一样的子目录存放新编译的驱动
mkdir -p ~/drivers/kingbases.com/gokb/
在这里插入图片描述

新建/home/kingbase/gotest目录,存放go测试代码gotest.go,简单测试代码的功能为连接位于192.168.40.101上的Kingbase ES V8R6数据库,端口:54321,连接成功打印connection test success!到控制台

[kingbase@oracle gotest]$ pwd
/home/kingbase/gotest
[kingbase@oracle gotest]$ cat gotest.go 
package main

import (
	"database/sql"
	"fmt"
	_ "kingbase.com/gokb"
)

func main() {
connStr := "host=192.168.40.101 user=system password=111111 dbname=test sslmode=disable"
db, err := sql.Open("kingbase", connStr)
err = db.Ping()

if err != nil {
	fmt.Println(err)
		return
	}
fmt.Println("Connection test success!")

if db != nil {
	db.Close()
		}

}
[kingbase@oracle gotest]$

生成go.mod:

[kingbase@oracle gotest]$ ls
gokb-source.tar.gz  gotest.go
[kingbase@oracle gotest]$ go mod init example.com/gotest
go: creating new go.mod: module example.com/gotest
go: to add module requirements and sums:
	go mod tidy
[kingbase@oracle gotest]$ cat go.mod 
module example.com/gotest

go 1.19
[kingbase@oracle gotest]$ 

编译gotest.go

使用静态库时,不能直接使用 go run 或者 go build 命令,这样无法正确链接库。
需要手动指定导入库的路径和需要链接库的路径。如下所示:
编译生成gotest.o:
在这里插入图片描述
链接生成可执行文件:
在这里插入图片描述
执行连库测试程序:
在这里插入图片描述

源码形式驱动使用

Kingbase自带的驱动只有1个版本,与本地环境未必一致,下面再介绍下,直接引用驱动源码连库的方法

1、把go驱动源码kingbase.com文件夹放入gopath所在路径(本人路径为/home/kingbase/go/src)
在这里插入图片描述
2、使用go mod edit命令编辑go.mod,让gotest.go程序可以找到驱动的位置
go mod edit -replace kingbase.com/gokb=驱动源码所在实际路径
例:
go mod edit -replace kingbase.com/gokb=/home/kingbase/go/src/kingbase.com/gokb

在这里插入图片描述
go mod edit执行完成后,go.mod中会增加一行:

replace kingbase.com/gokb => /home/kingbase/go/src/kingbase.com/gokb

再执行go mod tidy
在这里插入图片描述
执行完,go.mod会增加一行:
require kingbase.com/gokb v0.0.0-00010101000000-000000000000

直接使用源码,可以不用编译,接下来就可以直接用go run命令执行测试程序
在这里插入图片描述
以上内容,简单介绍了使用go语言连接kingbase数据库,希望对大家有用,谢谢!

参考资料:
https://pkg.go.dev/cmd/go#hdr-Compile_packages_and_dependencies

https://go.dev/doc/tutorial/call-module-code

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/114704.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL为什么使用B+树为索引结构

目录 1、什么是索引 2、索引的类型 3、为什么要用索引 4、索引的使用场景 5、索引为什么要用B树,为什么不能用二叉树、红黑树、B树? 介绍一款可以帮助理解数据结构的网站(很好用):Data Structure Visualization …

hadoop生产调优之Hadoop-Yarn 生产经验(参数调优)

一、常用的调优参数 1)调优参数列表 (1)Resourcemanager 相关 yarn.resourcemanager.scheduler.client.thread-count ResourceManager 处理调度器请求的线程数量 yarn.resourcemanager.scheduler.class 配置调度器(2&#xff0…

js中ArrayBuffer和node中Buffer的关系和区别

ArrayBuffer 对象用来表示通用的、固定长度的原始二进制数据缓冲区。 它是一个字节数组,通常在其他语言中称为“byte array”。你不能直接操作 ArrayBuffer 中的内容;而是要通过类型化数组对象或 DataView 对象来操作,它们会将缓冲区中的数据…

C++、python、VS code插件安装与SSH使用

下载按照VS coda 官网:https://code.visualstudio.com 1.安装相关插件 1.中文插件(可选) MS-CEINTL.vscode-language-pack-zh-hans 2.C插件(必选) ms-vscode.cpptools 3.ssh 远程(必选) ms-vs…

数据结构——快排的三种实现方式

坚持看完,结尾有思维导图总结 这里写目录标题什么是快排?如何实现递归单次的排序要如何实现hore 的办法![在这里插入图片描述](https://img-blog.csdnimg.cn/40b2ac63f2424bd1828a45f8509ff116.gif#pic_center)坑位法双指针法总结什么是快排?…

线程池(一)

个人博客地址: http://xiaohe-blog.top/index.php/archives/14/ 文章目录1. 为什么要使用线程池2. Executor3. ThreadPoolExecutor3.1 七个参数3.2 任务队列3.3 拒绝策略4. 创建线程池5. Executors5.1 CachedThreadPool5.2 FixedThreadPool5.3 SingleThreadExecutor…

SAP UI5 应用里一些容器控件的介绍

sap.m.Shell 控件可用作应用程序的根元素。 它可以包含 App 或 SplitApp 控件。 Shell 为整个应用程序提供了一些总体功能,并负责在桌面浏览器平台上进行视觉适配,例如应用程序周围的框架。 sap.m.App: 该 App 继承自 sap.m.NavContainer 并因此提供其导…

VUEElement 学习笔记

1 VUE 1.1 示例 新建test_vue.jsp <% page contentType"text/html;charsetUTF-8" language"java" %> <html> <head><title>Title</title> </head> <body><div id"app"><input name"…

三、SpringBoot启动流程及自动化配置

一、Springboot启动流程 图一:Springboot项目的启动流程 首先,针对上图中自己不太明确的两个知识点,这里做如下总结: 1.Banner:参考这篇文章:SpringBoot之Banner介绍 - MarkLogZhu - 博客园 (cnblogs.com) ; 2.钩子方…

【Javassist】快速入门系列07 当检测到字段被访问时使用语句块替换访问

系列文章目录 01 在方法体的开头或结尾插入代码 02 使用Javassist实现方法执行时间统计 03 使用Javassist实现方法异常处理 04 使用Javassist更改整个方法体 05 当有指定方法调用时替换方法调用的内容 06 当有构造方法调用时替换方法调用的内容 07 当检测到字段被访问时使用语…

一个最基本的lLinux驱动开发框架和编译驱动方式

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言一、编写驱动文件1.相关头文件2.驱动入口 &出口3.申明完整代码二、编译驱动的方式三、编译驱动1. 和内核一起编译&#xff1a;2. 编译成驱动模块&#xff1a…

Kafka消息写入流程

Kafka消息写入流程 0,写入消息简要流程图 1,从示例开始 在Kafka中,Producer实例是线程安全的,通常一个Producer的进程只需要生成一个Producer实例. 这样比一个进程中生成多个Producer实例的效率反而会更高. 在Producer的配置中,可以配置Producer的每个batch的内存缓冲区的大小…

如何下载最新的NDVI数据?需要翻墙,安装MRT,如何处理下载的NDVI数据?

一、下载NDVI数据 参照网站&#xff1a; https://www.zhihu.com/question/48176218 1、先在网站https://modis.gsfc.nasa.gov/data/dataprod/mod13.php查看要下载的数据 其实没什么要看的&#xff0c;就看下面这个图就可以了&#xff0c;根据下图找到自己要下载的数据简称&am…

Python实现猎人猎物优化算法(HPO)优化支持向量机分类模型(SVC算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 猎人猎物优化搜索算法(Hunter–prey optimizer, HPO)是由Naruei& Keynia于2022年提出的一种最新的优…

Hibernate-Validator的使用(一)

文章目录学习建议全部的约束注解关于NotEmpty和NotBlank的注意事项关于Size的注意事项约束注解可以放的位置JavaBeanValidator接口约束注解的继承性普通方法和构造方法入参和返回值ExecutableValidator 接口约束注解的继承性错误信息国际化显示定义message使用的消息key定义Val…

模仿现实生活中的通讯录(2)

距离第一篇已经过去很久&#xff0c;我之所以暂时放下通讯录&#xff0c;是因为学业颇多&#xff0c;无暇顾及。现在放假已经有一段时间了&#xff0c;脱离每天忙碌的生活后&#xff0c;我只想享受一下整日无事&#xff0c;浑浑噩噩过一天的感觉&#xff0c;只不过差点没收得住…

leetcode150/155. 逆波兰表达式求值、最小栈;剑指 Offer 31. 栈的压入、弹出序列

目录 题目链接与简介 题目一 1.算法思路 2.总结心得 3.可执行代码 题目二 1.算法思路 2.总结心得 3.可执行代码 题目三 1.算法思路 2.总结心得 3.可执行代码 题目链接与简介 1.逆波兰表达式求值 2.最小栈 3.剑指 Offer 31. 栈的压入、弹出序列 题目一 LeetCod…

软件测试 -- 进阶 8 软件测试流程和过程

盖天下之事&#xff0c;不难于立法&#xff0c;而难于法之必行&#xff1b;不难于听言&#xff0c;而难于言之必效。-- 明 张居正 释译&#xff1a;天下大事&#xff0c;困难的不在于要制定什么法律&#xff0c;而在于立了法就一定要执行&#xff1b;重要的不在于说什么&a…

【实时数仓】DWS层之地区主题表(FlinkSQL)、关键词主题表(FlinkSQL)

文章目录一 DWS层-地区主题表(FlinkSQL)1 分组开窗和聚合计算&#xff08;1&#xff09;分组窗口&#xff08;2&#xff09;选择分组窗口的开始和结束时间戳&#xff08;3&#xff09;系统内置函数&#xff08;4&#xff09;完整代码2 将动态表转换为流&#xff0c;写入ClickHo…

计算机基础(五):C语言的程序的处理过程

一段C语言程序 打开任何一个C语言的教程&#xff0c;首先自然是展示一段 Hello World 的程序&#xff0c;类似于下面这段&#xff1a; #include <stdio.h>int main() {/* 我的第一个 C 程序 */printf("Hello, World! \n");return 0; }运行上面这段程序也很简…