【Golang】gormでwhere,andを使用したときのシンタックスエラー対処を教えてほしいです
前提・実現したいこと
Golangのgormモジュールを使用して、データベースからデータを取りたいです。
以下のparticipantテーブルから、
order, game_room_idの値を指定して、その中で最新のデータを取得します。
Golang
1// Participantのテーブル情報 2type Participant struct { 3 ID int `gorm:"primary_key;suto_increment" json:"id"` 4 GameRoomId int `json:"game_room_id"` 5 UserId string `gorm:"type:varchar(50)" json:"user_id"` 6 UserDisplayName string `gorm:"type:varchar(50)" json:"user_display_name"` 7 Score int `json:"score"` 8 Order int `json:"order"` 9 CreatedAt string `json:"created_at" sql:"type:datetime"` 10}
発生している問題・エラーメッセージ
シンタックスエラー
SQLが文法的にどこか間違いがあるとのこと
Error 1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'order = ? AND game_room_id = ? ) ORDER BY `participants`.`id` DESC LIMIT 1' at line 1
該当のソースコード
Golang
1 // db接続 2 db, err := sqlConnect() 3 if err != nil { 4 panic(err.Error()) 5 }else{ 6 log.Println("DB connected ") 7 } 8 defer db.Close() 9 10 // モデルの初期化 11 participant:=Participant{} 12 13 //データの取得 14 db.Where(" order = ? AND game_room_id = ? ", order, game_room_id).Last(&participant) 15 16 //UserIdとUserDisplayIdを取得する 17 user_id:=participant.UserId 18 user_display_name:=participant.UserDisplayName 19
試したこと
SQLを以下に書き換えても実施しましたが、同様にシンタックスエラーでした
Golang
1db.Last(&participant, " order = ? AND game_room_id = ? ", order, game_room_id)
補足情報(FW/ツールのバージョンなど)
go version: go1.14.2 linux/amd64
回答1件
あなたの回答
tips
プレビュー