当前位置: 首页 > news >正文

中国空间站搭建国际合作平台seo公司是什么

中国空间站搭建国际合作平台,seo公司是什么,买域名价格,简洁的公司网站目录 模型定义使用Create创建记录一次性创建多条数据批量插入数据时开启事务默认值问题 模型定义 定义一个PersonInfo结构体。 type PersonInfo struct {Id uint64 gorm:"column:id;primary_key;NOT NULL" json:"id"UserName string gorm:"co…

目录

  • 模型定义
  • 使用Create创建记录
  • 一次性创建多条数据
  • 批量插入数据时开启事务
  • 默认值问题

模型定义

定义一个PersonInfo结构体。

type PersonInfo struct {Id       uint64 `gorm:"column:id;primary_key;NOT NULL" json:"id"`UserName string `gorm:"column:username;unique;NOT NULL" json:"username"`Password string `gorm:"column:password" json:"password"`Age      int    `gorm:"column:age" json:"age"`
}

使用Create创建记录

Create方法用于创建一条新的数据记录,并将其保存到数据库中。使用该方法时,需要传入一个指针,表示要创建的数据记录。

p1 := connect.PersonInfo{Id:       1,UserName: "abc",Password: "12345",Age:      19,}connect.DB.Create(&p1)

运行完成后,查询结果如下:

image-20230604085025895

一次性创建多条数据

第一种方法:使用 Create() 创建多项记录:

	p := []*connect.PersonInfo{{Id: 2, UserName: "def", Password: "56789", Age: 20},{Id: 3, UserName: "xyz", Password: "09876", Age: 22},}connect.DB.Create(&p)

运行完成后,查询结果如下:

image-20230604110931689

第二种方法:使用 CreateInBatches()方法。该方法可以一次性将多条数据记录批量插入到数据库中,从而提高插入数据的效率。CreateInBatches 方法的用法与 Create 方法基本相同,只是需要传入一个额外的参数,表示每批次插入的数据记录数量。使用CreateInBatches方法的好处就是CreateInBatches方法能够保证原子性,如果其中一条数据插入失败,则整个插入操作都会进行回滚。

p := []connect.PersonInfo{{Id: 4, UserName: "drg", Password: "5622", Age: 25},{Id: 5, UserName: "tes", Password: "0955", Age: 26},}connect.DB.CreateInBatches(p, 2)

运行完成后,查询结果如下:

image-20230604111734531

批量插入数据时开启事务

p := []connect.PersonInfo{{Id: 6, UserName: "edg", Password: "6722", Age: 24},{Id: 7, UserName: "dyg", Password: "0395", Age: 23},}tx := connect.DB.Begin() //开启事务for _, value := range p {tx.Create(&value)}tx.Commit() //提交事务

运行完成后,查询结果如下:

image-20230604112557961

上面的示例代码中,首先定义了一个名为p的结构体切片,其中包含2条数据记录。然后,调用 Begin 方法开启一个事务,循环遍历 p 切片,调用 Create 方法插入每条数据记录,最后调用 Commit 方法提交事务。与 CreateInBatches 方法类似,如果其中任何一个数据记录插入失败,整个事务都会回滚。

默认值问题

定义如下模型:

type User struct {Id       uint64UserName stringPassWord string `gorm:"default:'000000'"`Age      int    `gorm:"default:18"`
}

如果没有指定password,password就为000000;如果没有指定age,age就为18。

u := connect.User{Id:       1,UserName: "aaa",}connect.DB.Create(&u)
image-20230604115407950

注意: 通过tag定义字段的默认值,在创建记录时候生成的 SQL 语句会排除没有值或值为零值的字段。 在将记录插入到数据库后,Gorm会从数据库加载那些字段的默认值。举个例子:

u := connect.User{Id:       2,UserName: "bbb",PassWord: "",Age:      0,}connect.DB.Create(&u)

运行完成后,查询结果如下:

image-20230604115743351

可以看到,上面代码的执行结果并不是password为空值,age为0。而是password为000000,age为18。所以,当使用了tag的默认值功能的时候,其字段的零值, 比如0, “”,false或者其它零值,都不会保存到数据库内,而是使用他们的默认值。 如果想避免这种情况,可以考虑使用指针或实现 Scanner/Valuer接口,

1.使用指针方式实现零值存入数据库

使用指针重新定义模型:(将原来的string类型和int类型改为 *string 和 *int 类型。)

type User struct {Id       uint64UserName stringPassWord *string `gorm:"default:'000000'"`Age      *int    `gorm:"default:18"`
}

使用new函数进行赋值:

u := connect.User{Id:       2,UserName: "bbb",PassWord: new(string),Age:      new(int),}connect.DB.Create(&u)

运行完成后,查询结果如下:

image-20230604120802961

这样各种类型的零值或空值字段就能插入数据库了。

2.使用Scanner/Valuer接口方式实现零值存入数据库

模型定义如下:(将原来的string类型和int类型改为 sql.NullString 和 sql.NullInt64 类型。)

type User struct {Id       uint64UserName stringPassWord sql.NullString `gorm:"default:'000000'"` // sql.NullString 实现了Scanner/Valuer接口Age      sql.NullInt64  `gorm:"default:18"`       // sql.NullInt64 实现了Scanner/Valuer接口
}

赋值如下:

u := connect.User{Id:       3,UserName: "bing",PassWord: sql.NullString{String: "", Valid: true},Age:      sql.NullInt64{Int64: 0, Valid: true},}connect.DB.Create(&u)

运行完成后,查询结果如下:

image-20230604143256011
http://www.hkea.cn/news/894486/

相关文章:

  • 余姚网站建设的公司手机百度账号申请注册
  • 预付网站制作费怎么做凭证如何自制网站
  • 定制网站多少钱北京seo网站管理
  • 南昌做网站公司哪家好如何建立独立网站
  • 成都解放号网站建设什么是百度竞价
  • 网站优化的基本思想与原则百度号码
  • 沧州网站建设制作设计优化深圳seo优化推广
  • 建立一个网站需要什么技术网上培训机构
  • 网站设计与管理论文百度账号注册平台
  • 网站空间商推荐seo是什么职位缩写
  • 怎么建设boss网站文件外链
  • 百度推广网站建设费百度搜索引擎的网址是多少
  • php 手机网站 上传图片定制网站建设
  • 关于网站建设的问题百度关键词分析
  • 登录官方网站装修公司网络推广方案
  • 设计网站官网入口网站搜索优化方法
  • 网站优化qq群山东做网站
  • wordpress icomoon太原seo快速排名
  • 中华建设杂志网站记者数据指数
  • 网站开发测试情况南召seo快速排名价格
  • 上海仓储公司小红书seo优化
  • 南京建设公司网站网络营销整合推广
  • wordpress更改语言沈阳seo优化
  • wordpress免费网站世界大学排名
  • 做网站的属于什么专业?百度爱采购竞价推广
  • 网站建设一年多少恰东莞网站到首页排名
  • 新企业网站应该怎么做SEO优化广告联盟有哪些
  • 手机app开发网站建设软文推广文章案例
  • 网站自然排名百度经验官网登录
  • dz网站模板沧州网站优化公司