golang Gormの使用概要

1611 ワード

構造体を作成するときに、検索するテーブル名をTable Nameで指定できます.

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()
		}