卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章34623本站已运行393

如何解决 github.com/godror/godror 的 go 构建错误?

如何解决 github.com/godror/godror 的 go 构建错误?

php小编鱼仔在使用github.com/godror/godror这个go库构建时遇到了一些错误,让他困扰不已。为了解决这个问题,他进行了深入的研究和尝试,并总结了一些有效的解决方法。在本文中,我们将分享他的经验,帮助大家解决github.com/godror/godror的go构建错误,让大家能够顺利使用这个库进行开发工作。

问题内容

在 Mac OS 上,我尝试构建以下文件以在 Linux 计算机上运行。

package main

import (
    "context"
    "database/sql"
    _ "github.com/godror/godror"
)

func main() {
    dsn := "user/password@host:port/sid"

    // Open a connection to the Oracle database
    db, err := sql.Open("godror", dsn)
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()

    // Test the database connection
    ctx := context.Background()
    err = db.PingContext(ctx)
    if err != nil {
        panic(err.Error())
    }

    query := "SELECT * FROM table"
    rows, err := db.QueryContext(ctx, query)
    if err != nil {
        panic(err.Error())
    }
    defer rows.Close()

    if err := rows.Err(); err != nil {
        panic(err.Error())
    }
}

我使用以下命令来构建:

env GOOS=linux GOARCH=amd64 go 构建 db.go

错误:

# github.com/godror/godror
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:530:19: undefined: VersionInfo
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:531:19: undefined: VersionInfo
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:532:10: undefined: StartupMode
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:533:11: undefined: ShutdownMode
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:535:31: undefined: Event
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:535:42: undefined: SubscriptionOption
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:535:64: undefined: Subscription
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:536:31: undefined: ObjectType
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:537:59: undefined: Data
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:538:28: undefined: DirectLob
../../../../pkg/mod/github.com/godror/[email protected]/orahlp.go:538:28: too many errors

我能够针对 Mac OS 进行构建,但针对 Linux 进行构建时遇到问题。你能帮我解决这些错误吗?

解决方法

此交叉编译错误是由于 github.com/godror/godror 包使用 CGO 造成的。要编译应用程序,您需要有效的 gcc 安装和 CGO_ENABLED=1,如 自述文件。 您可以尝试使用 docker 为 linux/amd64 进行编译。

示例:

DOCKER_DEFAULT_PLATFORM=linux/amd64 docker run --rm -v "$PWD":/app -w /app golang:1.21 go build -v db.go

这将在 Docker 容器中构建应用程序并将可执行文件保存在当前目录中。

卓越飞翔博客
上一篇: 如何使用mongodb进行离线开发?
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏