gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-01 22:36:35 25 4
gpt4 key购买 nike

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

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com