我想从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并找不到任何此类连接的示例。 所以想知道如何解决它。
答案 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=?"