douqin1932 2018-03-21 13:02
浏览 41
已采纳

将查询移至处理程序将获得“未定义:db”(golang)

I am trying to use Golang as a REST API. I have managed to get handlers to work and queries as well. But not got a query inside a handler to work.

When the query resides within the main() it works:

func handleRequests() {
    http.HandleFunc("/getuser", Getuser)
}

---> this handler gets respons on localhost:8080/getuser

func Getuser(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintf(w, "Getuser")
}

func main() {
    handleRequests()

    //Connect to db

    rows, err := db.Queryx(`SELECT "USER_ID","USER_NAME" FROM user`)
    for rows.Next() {
        results := make(map[string]interface{})
        err = rows.MapScan(results)
    fmt.Printf("%#v
", results)
    }

    log.Fatal(http.ListenAndServe(":8080", nil))
}

But when I move the query to the handler it gives an error that the db is not defined.

func handleRequests() {
    http.HandleFunc("/getuser", Getuser)
}

---> this gives the error that the db is not defined

func Getuser(w http.ResponseWriter, r *http.Request) {
    rows, err := db.Queryx(`SELECT "USER_ID","USER_NAME" FROM user`)
    for rows.Next() {
        results := make(map[string]interface{})
        err = rows.MapScan(results)
    fmt.Printf("%#v
", results)
    }
}

func main() {
    handleRequests()

    //Connect to db

    log.Fatal(http.ListenAndServe(":8080", nil))
 }

EDIT

Full code inside the handler (added db var as suggested), but gives various errors on "err".

 var db *sqlx.DB <---solved the db problem

 func Getsign(w http.ResponseWriter, r *http.Request) {
    rows, err := db.Queryx(`SELECT "USER_ID","USER_NAME" FROM user`)
    for rows.Next() {
        results := make(map[string]interface{})
        err = rows.MapScan(results)
        fmt.Printf("%#v
", results)
    }

    defer rows.Close()

    if err := rows.Err(); err != nil {
        log.Fatal(err)
    }
}

Any tip what I am doing wrong?

  • 写回答

2条回答 默认 最新

  • douba2011 2018-03-21 13:24
    关注

    Define your db variable outside of main, e.g.:

    var db *sql.DB
    
    func handler(w http.ResponseWriter, r *http.Request) {
        rows, err := db.Query(...)
        // use it
    }
    
    func main() {
        db, _ = sql.Open(...)
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)