質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Q&A

解決済

1回答

1160閲覧

【Golang】gormでwhere,andを使用したときのシンタックスエラー対処を教えてほしいです

Heroto

総合スコア8

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

0グッド

0クリップ

投稿2020/05/23 08:04

編集2020/05/23 08:08

【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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Heroto

2020/05/23 08:19

はい。
guest

回答1

0

自己解決

解決方法:カラム名orderをorder_numberに変更
原因:カラム名をSQLの予約後であるorderにしていたため

投稿2020/05/26 23:39

Heroto

総合スコア8

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問