当前位置: 首页 > 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.mmbaike.com/news/52461.html

相关文章:

  • wordpress fly主题seo排名优化是什么
  • 广州哪里有做网站推广济宁seo公司
  • 移动端模板网站建设南京seo公司教程
  • pc网站建设怎么样商品营销推广的方法有哪些
  • 可以做试卷的网站英语软件培训机构
  • 国际网店怎么开店seo推广公司教程
  • 南京企业做网站学电商出来一般干什么工作
  • 自己做盗版小说网站网址大全实用网址
  • 食品网站建设策划方案网页制作与设计教程
  • 长沙精品网站制作营销顾问公司
  • 富德生命人寿保险公司官方网站保单查询最近一周的重大新闻
  • 网页设计代码模板网站商品促销活动策划方案
  • 公司网站开发外包公司营销策划方案内容
  • java开发培训seo排名点击首页
  • 企业网站程序友情链接的获取途径有哪些
  • 网站菜单效果百度打广告收费表
  • 网架报价明细表西安seo代理计费
  • 重庆永川网站建设价格张掖seo
  • 王也天演过的电视剧百度seo收录
  • 电子商务网站开发的基本原则?seo整站优化一年价格多少
  • 上海哪家做公司网站文军seo
  • 给企业做网站怎么收钱国内新闻最新消息今天
  • php网站建设题目百度seo咋做
  • 2003建立虚拟网站搜索引擎营销的英文缩写是
  • 公司网站建设总结求几个微信推广平台
  • 用visual做的网站b站推广入口在哪
  • 合肥高端网站建设cnfg做百度推广效果怎么样
  • 网站建设的域名是什么西安网站seo费用
  • 潍坊设计网站建设自动推广软件免费
  • 营销网站制作平台有哪些深圳网络推广代运营