2017-07-20 9 views
-1

私はjokeのテーブルから結果を得たいと思います。 jokevoteのテーブルでジョークをアップします。ここsqlxを使用してLEFT JOINクエリを作成する方法は?

クエリである:

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 

」は、ユーザーID、USERID) 誤る=ゼロ{ fmt.Println(IF! "%のVを\ n"、ERR)
}

Error 1064: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'WHERE joke.user_id=? AND jokevote.user_id=? AND jokevote.vote=1' at line 1

私も試してみました:

01しかし、私はこのエラーを取得します
err := shared.Dbmap.Select(&jokes, " SELECT * 
    FROM joke 
    LEFT JOIN jokevote 
    WHERE joke.user_id=jokevote.user_id 
     AND jokevote.vote=? 

」、1)

と同じエラーを得ました。 私はthe docsを見て、そのような結合の例を見つけることができませんでした。 どうすればいいのでしょうか。

+1

このエラーは、 'sqlx'または' go'とは関係ありません。 SQL構文エラーがあります。 DBエディタでSQLクエリを実行し、クエリを修正します。その後、Goコードでそのクエリを使用します。 – jeevatkm

+0

LEFT JOINを使用する場合は、ON句が必要です。さもなければLEFTは無意味です。 –

答えて

2

例私はmariadbドキュメントになります。あなたが欠けているものはon句で、mariadbに2つのテーブルを結合する方法を教えてくれます。結合条件をwhere句に入れると、旧式の結合構文ではleft joinを使用できません。

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

先端が良い。しかし、私はまだ実行時にこのエラーが発生します: '行方不明の宛先名joke_id'。これがどうして起こるのか? – Karlom

+0

これはSQLエラーメッセージではありません。あなたが今質問した質問とは無関係のようです。別の質問がある場合、plsは新しい質問をします。 – Shadow

1

SQLクエリは次のようにする必要があります:

"SELECT * FROM joke LEFT JOIN jokevote ON joke.user_id=jokevote.user_id WHERE jokevote.vote=?" 
関連する問題