golang Gormの使用概要
1611 ワード
構造体を作成するときに、検索するテーブル名をTable Nameで指定できます.
gormのマッピングで対応するテーブルの列を指定
プリロードによって各モデル間の一対の多関係を実現することができ、例えば以下のコードであり、device構造体は複数のDeviceModularに対応し、DeviceModularは複数のCommWeimaqiを有し、以下のクエリ文によって対応する関連データを検索することができる.
gormは一時的に一括挿入をサポートしていませんが、以下のように一括挿入の機能を完了できます.
func (CoinLog) TableName() string {
return "coin_log"
}
gormのマッピングで対応するテーブルの列を指定
ID int64 `gorm:"column:id" json:"id"`
プリロードによって各モデル間の一対の多関係を実現することができ、例えば以下のコードであり、device構造体は複数のDeviceModularに対応し、DeviceModularは複数のCommWeimaqiを有し、以下のクエリ文によって対応する関連データを検索することができる.
db.SqlDB.Preload("DeviceModular", "modular_type=1").Preload("DeviceModular.CommWeimaqi").Find(&device)
gormは一時的に一括挿入をサポートしていませんが、以下のように一括挿入の機能を完了できます.
tx := db.SqlDB.Begin()
sqlStr := "INSERT INTO report_form (id,create_time,choose_count, device_fall_count,game_order_count,coin_count,member_count," +
"day_member_count,visit_count,lgz_coin_count,weimaqi_coin_count,store_id,real_coin_count,m_coin_count,coin_spec) VALUES "
vals := []interface{}{}
const rowSQL = "(?,?, ?, ?, ?, ?, ?, ?, ?, ?,?,?,?,?,?)"
var inserts []string
for _, elem := range reportForms {
inserts = append(inserts, rowSQL)
vals = append(vals, elem.ID, elem.CreateTime, elem.ChooseCount, elem.DeviceFallCount, elem.GameOrderCount, elem.CoinCount, elem.MemberCount, elem.DayMemberCount, elem.VisitCount, elem.LgzCoinCount, elem.WeimaqiCoinCount, elem.StoreId, elem.RealCoinCount, elem.MCoinCount, elem.CoinSpec)
}
sqlStr = sqlStr + strings.Join(inserts, ",")
err := tx.Exec(sqlStr, vals...).Error
if err != nil {
tx.Rollback()
fmt.Print(err)
}else {
tx.Commit()
}