Golang - 为什么SQL占位符不起作用?

时间:2016-06-14 16:36:50

标签: mysql sql go

我的代码如下(我使用gorm):

e.GET("/search", func(c echo.Context) error {
    keyword := c.QueryParam("keyword")

    results := make([]searchResult, 0)
    if keyword != "" {
        db, err := models.ConnectDB()
        defer db.Close()
        if err != nil {
            return err
        }

        rows, err := db.Raw("SELECT songs.name, singers.name, albums.name FROM songs, singers, albums WHERE (songs.singer_id = singers.id AND songs.album_id = albums.id) AND (songs.name LIKE '%?%' OR singers.name LIKE '%?%' OR albums.name LIKE '%?%')", keyword, keyword, keyword).Rows()
        defer rows.Close()

        var songName, singerName, albumName string
        if err == nil {
            for rows.Next() {
                rows.Scan(&songName, &singerName, &albumName)
                results = append(results, searchResult{
                    SongName:   songName,
                    SingerName: singerName,
                    AlbumName:  albumName,
                })
            }
        } else {
            return err
        }
    }
    return c.Render(http.StatusOK, "search", results)
})

我收到错误:sql: statement expects 0 inputs; got 3,这意味着占位符没有被解析。谁能给我一些想法?

我自己也找不到原因。

请帮帮我。感谢。

1 个答案:

答案 0 :(得分:4)

您不能将占位符放在'?'之类的字符串中。

它不像字符串插值那样只是变量绑定。

所以试试:

    searchKeyword := "%" + keyword + "%"
    rows, err := db.Raw(`SELECT songs.name, singers.name, albums.name 
      FROM songs, singers, albums 
      WHERE (songs.singer_id = singers.id AND songs.album_id = albums.id) 
      AND (songs.name LIKE ? OR singers.name LIKE ? OR albums.name LIKE ?)`, 
      searchKeyword, 
      searchKeyword, 
      searchKeyword).Rows()