duancaoqin6683 2015-12-12 03:49 采纳率: 0%
浏览 651
已采纳

如何从go-sqlite3查询获取计数值?

I am using go-sqlite3 to retrieve the number of rows with a column of a certain value:

query := "select count(notebook) from pages where notebook="
result, err := db.Query(fmt.Sprint(query, id))

Where id is passed to the function running the query.

How can I retrieve the count value from result?

  • 写回答

1条回答 默认 最新

  • dsu5188 2015-12-12 04:27
    关注

    This should work:

    // Output will be stored here.
    var output string
    
    id := "1234"
    
     // Prepare your query
    query, err := db.Prepare("select count(notebook) from pages where notebook = ?")
    
    if err != nil {
        fmt.Printf("%s", err)
    }
    
    defer query.Close()
    
    // Execute query using 'id' and place value into 'output'
    err = query.QueryRow(id).Scan(&output)
    
    // Catch errors
    switch {
    case err == sql.ErrNoRows:
            fmt.Printf("No notebook with that ID.")
    case err != nil:
            fmt.Printf("%s", err)
    default:
            fmt.Printf("Counted %s notebooks
    ", output)
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?