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

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

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

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

Q&A

1回答

2635閲覧

Goのgormについて

mhl

総合スコア34

Go

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

0グッド

0クリップ

投稿2016/12/02 01:45

いつもお世話になっています。

最近Go言語を勉強中なのですが、ひとつわからないことがあり、皆様のお力をお借りしたいと思い投稿しました。

例1:

go

1//dbのtable設定 2type Hoge struct { 3 gorm.Model 4 Name string `sql:"size:255" json:"name" validate:"max=255"` 5 Movies []Movie `gorm:"many2many:movie_tags;"` 6} 7//ある2つの配列 8array := []string{"bar", "foo"} 9ids := []unit{} 10//array配列の値がhogesテーブルにあるかwhereで検索 11for _, v := range array { 12 s := Hoge{} 13 db.Where("name = ?", v).Find(&s) 14 //hogesのidをidsに追加する 15 ids = append(ids, v.ID) 16}

結果

sql

1SELECT * FROM `hoges` WHERE `hoges`.deleted_at IS NULL AND ((name = 'bar')) 2SELECT * FROM `hoges` WHERE `hoges`.deleted_at IS NULL AND ((name = 'foo'))

idsの中身

[1,2]

例2:

go

1//dbのtable設定 2type Hoge struct { 3 gorm.Model 4 Name string `sql:"size:255" json:"name" validate:"max=255"` 5 Movies []Movie `gorm:"many2many:movie_tags;"` 6} 7//ある2つの配列 8array := []string{"bar", "foo"} 9ids := []unit{} 10s := Hoge{} 11//array配列の値がhogesテーブルにあるかwhereで検索 12for _, v := range array { 13 db.Where("name = ?", v).Find(&s) 14 //hogesのidをidsに追加する 15 ids = append(ids, v.ID) 16}

sql

1SELECT * FROM `hoges` WHERE `hoges`.deleted_at IS NULL AND `tags`.`id` = '1' AND ((name = 'bar')) 2SELECT * FROM `hoges` WHERE `hoges`.deleted_at IS NULL AND `tags`.`id` = '1' AND ((name = 'foo'))

idsの中身

[1,1]

このように変数s := Hoge{}をforの中に書くか外に書くかでsql文が変わるのはなぜでしょうか?

どなたかご存知でしたらご教示ください。
初歩的な質問ですみませんが、よろしくお願いします。

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

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

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

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

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

guest

回答1

0

質問のソースはコピペしましたか?
v.IDになってますが、vはfor文的にstringが入りそうです。

投稿2016/12/12 15:46

kokardy

総合スコア781

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問