如何使用sqlx进行LEFT JOIN查询?

时间:2017-07-20 04:54:24

标签: mysql go mariadb sqlx

我想从joke表中获取结果,其中笑话被更新  jokevote表。

以下是查询:

var jokes []model.Joke
err := shared.Dbmap.Select(&jokes, "    SELECT  *
    FROM  joke
    LEFT JOIN  jokevote
    WHERE  joke.user_id=?
      AND  jokevote.user_id=?
      AND  jokevote.vote=1

“,userId,userId)     if err!= nil {         fmt.Println(“%v \ n”,错误)
    }

但是我收到了这个错误:

  

错误1064:您的SQL语法出错;检查手册   对应于您的MariaDB服务器版本以获得正确的语法   在'WHERE joke.user_id =附近使用?和jokevote.user_id =?和   第1行的jokevote.vote = 1'

我也尝试过:

err := shared.Dbmap.Select(&jokes, "    SELECT  *
    FROM  joke
    LEFT JOIN  jokevote
    WHERE  joke.user_id=jokevote.user_id
      AND  jokevote.vote=?

“,1)

并得到了同样的错误。 我查看the docs并找不到任何此类连接的示例。 所以想知道如何解决它。

2 个答案:

答案 0 :(得分:2)

我在mariadb文档中的例子。您缺少的是on子句,告诉mariadb如何加入2个表。您不能将{ - 1}}的旧学习连接语法用于将加入条件放入left join子句中。

where

答案 1 :(得分:1)

Sql查询应该像:

"SELECT * FROM joke LEFT JOIN jokevote ON joke.user_id=jokevote.user_id WHERE  jokevote.vote=?"