go - pq QueryRow 扫描失败,内存地址无效或指针取消引用

标签 go pq

我有以下函数应该从我的想法表中检索一行:

func (s *IdeaService) GetIdea(id int64) (*ideaservice.Idea, error) {
    stmt, err := s.DB.Prepare("SELECT id, name, description, created_on, last_updated FROM ideas WHERE id = $1")
    if err != nil {
        return nil, err
    }
    defer stmt.Close()
    var idea *ideaservice.Idea
    err = stmt.QueryRow(id).Scan(&idea.ID, &idea.Name, &idea.Description, &idea.CreatedOn, &idea.LastUpdated)
    return idea, err
}

当我在测试中运行它时,会出现以下错误:
--- FAIL: TestGetIdea (0.00s)
panic: runtime error: invalid memory address or nil pointer dereference [recovered]
    panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x0 pc=0x65be98]

我似乎无法弄清楚问题所在。我相信我已经将 idea var 正确地实例化为指针,然后我在 Scan 方法中为其赋值。有没有人有什么建议?

最佳答案

func (s *IdeaService) GetIdea(id int64) (*ideaservice.Idea, error) {
    stmt, err := s.DB.Prepare("SELECT id, name, description, created_on, last_updated FROM ideas WHERE id = $1")
    if err != nil {
        return nil, err
    }
    defer stmt.Close()
    var idea *ideaservice.Idea
    err = stmt.QueryRow(id).Scan(&idea.ID, &idea.Name, &idea.Description, &idea.CreatedOn, &idea.LastUpdated)
    return idea, err
}

你能替换$1吗?与 ?看看它是否有效?在 stmt.QueryRow您正在传递 id .像这样:

stmt, err := s.DB.Prepare("SELECT id, name, description, created_on, last_updated FROM ideas WHERE id = ?")

如果它不起作用,则添加此 block :

switch {
    case err == sql.ErrNoRows:
        log.Fatalf("no user with id %d", id)
    case err != nil:
        log.Fatal(err)
    default:
        log.Println("ok!")
    }

更新:没有看到关于这个问题的评论。是的,他也是正确的。也要修复它们。

并检查 err 的位置被困(在这种情况下)。

关于go - pq QueryRow 扫描失败,内存地址无效或指针取消引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61272426/

相关文章:

go - LeetCode排列-代码日志

go - 如何检查是否已写入标准输出?

postgresql - 如何使用 lib/pq 驱动程序插入 NUMERIC 字段类型?

go - 从 PostgreSQL 查询整数数组总是返回 []uint8

go - 从 goroutine 更改变量

复合结构的 JSON 编码(marshal)处理,均实现 MarshalJSON()

http - 将对 GO web 服务的访问限制为来自本地子网的客户端

postgresql - 如何一次性将多行插入 postgresQL

postgresql - Go database/sql - 重新连接时发出命令

postgresql - 如何设置 pgx 以从数据库中获取 UTC 值?