创建记录

  1. user := User{Name: "Jinzhu", Age: 18, Birthday: time.Now()}
  2. db.NewRecord(user) // => 主键为空返回`true`
  3. db.Create(&user)
  4. db.NewRecord(user) // => 创建`user`后返回`false`

默认值

你可以通过 tag 定义字段的默认值,比如:

  1. type Animal struct {
  2. ID int64
  3. Name string `gorm:"default:'galeone'"`
  4. Age int64
  5. }

生成的 SQL 语句会排除没有值或值为 零值 的字段。 将记录插入到数据库后,Gorm会从数据库加载那些字段的值。

  1. var animal = Animal{Age: 99, Name: ""}
  2. db.Create(&animal)
  3. // INSERT INTO animals("age") values('99');
  4. // SELECT name from animals WHERE ID=111; // 返回主键为 111
  5. // animal.Name => 'galeone'

注意 所有字段的零值, 比如 0, ‘’, false 或者其它 零值,都不会保存到数据库内,但会使用他们的默认值。 如果你想避免这种情况,可以考虑使用指针或实现 Scanner/Valuer 接口,比如:

  1. // 使用指针
  2. type User struct {
  3. gorm.Model
  4. Name string
  5. Age *int `gorm:"default:18"`
  6. }
  7. // 使用 Scanner/Valuer
  8. type User struct {
  9. gorm.Model
  10. Name string
  11. Age sql.NullInt64 `gorm:"default:18"` // sql.NullInt64 实现了Scanner/Valuer接口
  12. }

在Hooks中设置字段值

如果你想在BeforeCreate hook 中修改字段的值,可以使用scope.SetColumn,例如:

  1. func (user *User) BeforeCreate(scope *gorm.Scope) error {
  2. scope.SetColumn("ID", uuid.New())
  3. return nil
  4. }

扩展创建选项

  1. // 为Instert语句添加扩展SQL选项
  2. db.Set("gorm:insert_option", "ON CONFLICT").Create(&product)
  3. // INSERT INTO products (name, code) VALUES ("name", "code") ON CONFLICT;