登录
首页 >  Golang >  Go问答

连接Windows操作系统和DB2服务器使用Golang

来源:stackoverflow

时间:2024-03-06 19:51:26 442浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《连接Windows操作系统和DB2服务器使用Golang》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

问题内容

我正在尝试使用 golang 连接到 db2 数据库。我正在使用包进行连接并使用名为 v10.1fp6_ntx64_odbc_cli 的 db2 客户端。

但是,当我看到 phiggins 包上的说明时,它建议在提供一些环境变量后重建包

#!/bin/bash

 DB2HOME=$HOME/sqllib
 export CGO_LDFLAGS=-L$DB2HOME/lib
 export CGO_CFLAGS=-I$DB2HOME/include

 go build .

我是 golang 新手,不知道如何在 windows 上执行此操作。我尝试使用设置环境变量来做到这一点,但不起作用。出现错误

恐慌:无法加载 db2cli64.dll:找不到指定的模块。 goroutine 1 [运行]: 系统调用。(*lazyproc).mustfind(0xc000060270) c:/go/src/syscall/dll_windows.go:280 +0x5f 系统调用。(*lazyproc).addr(0xc000060270, 0x64) c:/go/src/syscall/dll_windows.go:287 +0x32 bitbucket.org/phiggins/db2cli/api.sqlallochandle(0x4f0001, 0x0, 0xc000071ef8, 0xc000071f00) c:/users/myuser/go/src/bitbucket.org/phiggins/db2cli/api/zapi_windows.go:44 +0x34 bitbucket.org/phiggins/db2cli.initdriver(0x0, 0x0) c:/users/myuser/go/src/bitbucket.org/phiggins/db2cli/driver.go:26 +0x57 bitbucket.org/phiggins/db2cli.init.0() c:/users/myuser/go/src/bitbucket.org/phiggins/db2cli/driver.go:52 +0x29 退出状态2

请帮我解决这个问题,希望使用 golang 连接到 db2 数据库。


解决方案


以下步骤让我在 windows7 pro x64 上从 golang 连接到 db2。 你的旅费可能会改变。

我使用了最新的适用于 windows x64 的“db2 runtime client”软件包,可从 ibm 网站下载(在我的例子中,版本为 11.1.3.3b),下载的文件名是 v11.1.3fp3b_ntx64_rtcl.exe

它本地安装在位置 "c:\program files\ibm\sqllib" 位置(默认)。

我已经在 windows7 上为其他项目安装了一个可用的 gcc(可能来自 mingw)。

我在 db2cmd.exe 窗口中验证,我可以使用特定端口号和特定凭据通过 clp(使用 cli)成功连接到感兴趣的数据库。这样我就知道 db2-client 已正确安装,并且 db2-server 正在运行,数据库可用,并且凭据和端口都正常。

以本地管理员身份运行,通过从 golang.org/dl 下载的 msi 文件将 go for windows 安装到默认位置 c:\go

https://bitbucket.org/phiggins/db2cli 下载了 phiggins-db2cli-*.zip

已创建本地目录:mkdir %userprofile%\go\src\bitbucket.org\phiggins\db2cli

将 phiggins-db2cli-*.zip 的内容解压到 %userprofile%\go\src\bitbucket.org\phiggins\db2cli

在以管理员身份运行的 db2cmd.exe 窗口中:

cd %userprofile%\go\src\bitbucket.org\phiggins\db2cli

创建了一个包含以下内容的批处理文件 buildgo.bat

set db2home="c:\program files\ibm\sqllib"

set cgo_ldflags=-l"c:\program files\ibm\sqllib\lib"

set cgo_cflags=-i"c:\program files\ibm\sqllib\include"

go build .

在以管理员身份运行的 db2cmd 窗口中,运行批处理文件,它完成时没有错误或错误级别为 0 的消息。

在同一个 db2cmd 窗口中,创建了一个包含 https://bitbucket.org/phiggins/db2cli 所示示例程序的文件

我创建的文件名为 testgo.go

然后我执行示例程序:

go run testgo.co -conn DATABASE=sample;HOSTNAME=whatever;PORT=60000;UID=whatever;PWD=whatever;

--> 成功在屏幕上获取结果集

本篇关于《连接Windows操作系统和DB2服务器使用Golang》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>