【问题标题】:How to append URI as string in SQL query如何在 SQL 查询中将 URI 作为字符串附加
【发布时间】:2015-04-22 16:48:35
【问题描述】:

看起来很简单,但我做不到。 浏览domain.com/post/1时,应该显示id行中的数据,哪个值1

id 行是整数 (int4)。

下面的代码不起作用:

package main

import "fmt"
import "github.com/go-martini/martini"
import "net/http"
import "database/sql"
import _ "github.com/lib/pq"

func SetupDB() *sql.DB {
  db, err := sql.Open("postgres", "user=postgres password=apassword dbname=lesson4 sslmode=disable")
  PanicIf(err)
  return db
}

func PanicIf(err error) {
  if err != nil {
    panic(err)
  }
}

func main() {
  m := martini.Classic()
  m.Map(SetupDB())

  m.Get("/post/:idnumber", func(rw http.ResponseWriter, r *http.Request, db *sql.DB) {

    rows, err := db.Query(`SELECT title, author, description FROM books WHERE id = params["idnumber"]`)
    PanicIf(err)
    defer rows.Close()

    var title, author, description string
    for rows.Next() {
      err:= rows.Scan(&title, &author, &description)
      PanicIf(err)
      fmt.Fprintf(rw, "Title: %s\nAuthor: %s\nDescription: %s\n\n",
        title, author, description)
    }

  })

  m.Run()
}

【问题讨论】:

  • 你说不工作是什么意思?是不是在sql中找不到行?
  • 我总是让它不工作并给出错误。尝试了各种方式。我只是不知道
  • 我忘记了一些关于参数的事情。

标签: sql postgresql go martini


【解决方案1】:

部分问题是您将字符串 params["idnumber"] 用作 SQL 查询的一部分

db.Query(`SELECT title, author, description FROM books WHERE id = params["idnumber"]`)

这将查找 id 等于 params["idnumber"] 字符串的书。

你需要做的是根据http://golang.org/pkg/database/sql/#DB.Query使用占位符和参数

在这种情况下,您的查询应该是

db.Query("SELECT title, author, description FROM books WHERE id=$1", params["idnumber"]) 

这应该可以解决我认为您遇到的问题。但是,在您实际使用您遇到的实际问题更新您的问题之前,我不会知道。

更新

undefined: params 出现的错误是因为范围内没有 params 对象。

我建议阅读马提尼酒在消除争论方面的工作原理。 https://github.com/go-martini/martini#routing

【讨论】:

  • 我忘了添加params martini.Params。您的代码现在可以使用。谢谢
【解决方案2】:

我认为问题在于您在字符串文字查询中使用了变量名,而您希望它是那里的值。

尝试更改此设置;

rows, err := db.Query(`SELECT title, author, description FROM books WHERE id = params["idnumber"]`)

到;

rows, err := db.Query("SELECT title, author, description FROM books WHERE id =$1", params["idnumber"])

除此之外,您可能还有其他问题,但鉴于您没有正确形成查询,我不希望您得到想要的结果。

【讨论】:

  • 也得到了像 Leo Correa 回答这样的错误。第 27 行错误:未定义:参数
  • @apasajja 是的,你只是突然使用了参数,而没有在任何地方声明它。 m 是什么?您正在寻找请求 url.Values,它是一个键值对字典,您需要先输入所需的字符串格式,然后再将其传递到您的查询中。
  • 是的。我忘了加params martini.Params。不幸的是,您的代码在添加参数声明后不起作用,而 Leo Correa 代码有效。 m 是马提尼酒。是的,将 URI 作为部分数据库查询 (SQL) 附加。
  • @apasajja 我想我的查询字符串中有错误的标记( ? 应该是 $1 ),我只是按照 go docs 示例进行操作。
猜你喜欢
  • 2017-06-29
  • 1970-01-01
  • 1970-01-01
  • 2012-12-28
  • 2013-01-09
  • 1970-01-01
  • 2017-03-29
相关资源
最近更新 更多