我希望从 lib/pg 切换到 pgx,但我无法获得一个简单的工作选择来在 pgx 中工作。想知道是否有人可以指出这段代码有什么问题。为什么它不工作?
lib/pg 没问题,但 pgx 肯定是缺少的东西。我修改了 pgx 示例代码中的测试代码来测试我的选择。
我已经发布了我修改的代码以及代码运行时的错误。由于选择返回,我看不到我怎么会有无效的内存地址。也许有人可以指出这段代码发生了什么。
package main
import (
"context"
"fmt"
"os"
"github.com/jackc/pgx"
)
var conn *pgx.Conn
var err error
func main() {
conn, err = pgx.Connect(context.Background(), os.Getenv("DATABASE_URL"))
if err != nil {
fmt.Fprintf(os.Stderr, "Unable to connection to database: %v\n", err)
os.Exit(1)
}
listTasks()
defer conn.Close(context.Background())
}
func listTasks() error {
rows, _ := conn.Query(context.Background(), "select * from signal")
for rows.Next() {
var s string
var id int32
var v float64
var description string
var description2 string
err := rows.Scan(&s, &id, &v, &description, &description2)
if err != nil {
return err
}
fmt.Printf("%d. %s\n", id, description)
}
return rows.Err()
}
这是我得到的错误
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x4 pc=0x29eb30]
goroutine 1 [running]:
github.com/jackc/pgx.(*Conn).Query(0x0, 0x38deb8, 0x1414090, 0x3238d7, 0x14, 0x0, 0x0, 0x0, 0x14126c0, 0x192e8, ...)
/home/forex/go/src/github.com/jackc/pgx/conn.go:585 +0x18
main.listTasks(0x38deb8, 0x1414090)
/usr/local/forex/test-pgx.go:27 +0x58
main.main()
/usr/local/forex/test-pgx.go:22 +0xbc