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

wordpress建站以后网站建设语言都有什么软件

wordpress建站以后,网站建设语言都有什么软件,网页搜索框的记录怎么删除,旅游网站需求分析情景介绍 使用go语言,我需要保存xxxTime的字段至数据库中,这个字段可能为空,也可能是一段时间。我采取的是统一先赋值为空,若有需要,则再进行插入(需要根据另一个字段判断是否插入) 在我的数据…

情景介绍

使用go语言,我需要保存xxxTime的字段至数据库中,这个字段可能为空,也可能是一段时间。我采取的是统一先赋值为空,若有需要,则再进行插入(需要根据另一个字段判断是否插入)
在我的数据库中,使用的是DATETIME类型字段,代码中,采用的是time.Time 类型(这里有几个修改)。

使用Gorm库的实现

将xxxTime字段设置为sql.NullTime类型

在存储前,设置时

	res := Result{...省略...xxxTime: sql.NullTime{Time:  time.Time{},Valid: false,},...省略...}

在存储时

	if err := db.Table(Table1).Create(&res).Error; err != nil {log.Error("保存数据时出错:", err)return -1, err}

即可保存一条null值

在这里插入图片描述

之后采用进行插入即可

currentTime := time.Now()tmpTime := currentTime.Add(time.Duration(msgInfo.RetryIntervalMinutes) * time.Minute)xxxTime = tmpTime.Format("2006-01-02 15:04:05")       err := db.Table(Table1).Where("id = ?", id).Update(xxxTime, xxxTime).Error

使用ENT库

使用ent库进行同样的操作,但是遇到了很多问题。

使用sql.NullTime格式

遭遇失败

首先是采取同样的方式:同样是设置格式为sql.NullTime(此处导入的是import "entgo.io/ent/dialect/sql",先前版本导入的是import "database/sql")
同样赋值操作是

	res := Result{xxxTime: sql.NullTime{Time:  time.Time{},Valid: false,}}

保存操作为

		SetxxxTime(res.xxxTime)

但是会在这句报错,报错内容为:无法将 ‘res.xxxTime’ (类型 sql.NullTime) 用作类型 time.Time

如果换为"database/sql"中的nulltime,依旧报错。无法将 'res.xxxTime' (类型 sql.NullTime) 用作类型 time.Time

毕竟生成的代码中,所接受的传参就是t time.Time格式而不是其他,故显然是无法sql.nullTime的的…


// SetxxxTime sets the "xxx" field.
func (dlsc *DeadLetterServerCreate) SetxxxTime(t time.Time) *DeadLetterServerCreate {dlsc.mutation.SetxxxTime(t)return dlsc
}// SetNillablexxxTime sets the "xxx" field if the given value is not nil.
func (dlsc *DeadLetterServerCreate) SetNillablexxxTime(t *time.Time) *DeadLetterServerCreate {if t != nil {dlsc.SetxxxTime(*t)}return dlsc
}

为什么gorm可以?

而为什么gorm中可以呢?

func (db *DB) Create(value interface{}) (tx *DB) {if db.CreateBatchSize > 0 {return db.CreateInBatches(value, db.CreateBatchSize)}tx = db.getInstance()tx.Statement.Dest = valuereturn tx.callbacks.Create().Execute(tx)
}

翻看gorm中Create的源码,发现他所接受的是interface{}接口,因此就可以了…

保存为指针类型

参考此篇文章,里面是gorm库下的解决方啊,他提供了两种方法——sql.nullTime和保存为指针。因此照猫画虎,尝试第二种方案——保存为指针。

修改相关代码如下:

	xxx *time.Time `db:"xxx"`res := Result{xxx: nil,}

报错同上:毕竟是指定死类型的不是接口,所以肯定不对…
无法将 'res.xxx' (类型 *time.Time) 用作类型 time.Time

采用自动生成的 SetNillablexxx方法

在上面查看生成代码中,发现了这样一个函数

// SetNillablexxx sets the "xxx" field if the given value is not nil.
func (dlsc *DeadLetterServerCreate) SetNillablexxx(t *time.Time) *DeadLetterServerCreate {if t != nil {dlsc.Setxxx(*t)}return dlsc
}

他看起来就是实现了这样的功能,因此我们修改调用为这个。

SetNillableNextRetryTime(res.NextRetryTime).

运行后发现,可以正常保存。
在这里插入图片描述

完结,撒花!!

新的问题

这样可以保存NULL了,但我想真正保存时间时候,却无法保存了…

	testTime := time.Now()mh.Db.MainDB.UpdateOneID(id).SetNillableNextRetryTime(&testTime)

前面一直以为是格式化问题,修改了半天还是不行。。
后来我直接用这样的语句,结果都存不进去东西。

遂修改,增加错误输出:

mh.Db.MainDB.UpdateOneID(id).SetNillableNextRetryTime(&nextRetryTime)

结果错误是nil,然后这时候,他就神奇的,成功了…!!
迷惑ing

参考资源

问如何告诉gorm将缺少的time.Time字段保存为NULL,而不是’0000-00-00’?

ent官方FAQ

http://www.yayakq.cn/news/928296/

相关文章:

  • 加油站项目建设背景网站搭建公司
  • wap网站制作教程wordpress定时发布批量改已发布
  • 上海做网站建设公司排名seo实战技术培训
  • 沈阳网站建设服务深圳地址大全
  • 网站建设网站设计哪家专业东营专业网站建设公司电话
  • 学网站建设多久能学会长沙网站推广 下拉通推广
  • 如何建立一个网站查询数据聊城集团网站建设
  • 设计公司网站需要多少钱在线观看的免费
  • 流量网站12个优秀的平面设计素材网站的排名
  • 去国外做赌钱网站今天体育新闻
  • 资兴市网站建设服务商中国人才网登录入口
  • 天猫店的网站怎么做的网站备案分为几种
  • 帮一个企业做网站流程wordpress图片展示主题
  • 创做阿里巴巴网站流程石家庄网站建设seo优化营销
  • 青岛制作网站软件有服务器怎么做网站教程
  • 滨州网站开发公司家庭网络设计方案
  • 怎么做网站怎么引入广告挣钱做网站的公司哪里好
  • 长春专业企业网站建设价格织梦模板安装详细教程
  • 关于做公司官方网站域名申请上海申远装饰公司官网
  • 网站建设专业培训php mysql怎么编写视频网站
  • 专业网站制作公司地址台州网站建设哪家公司好
  • 东莞市建设安监局网站首页昌平知名的网站制作建设报价
  • 网站 建设 深圳台州黄岩做网站
  • 四川省住房和城乡建设厅网站无法进入正能量网站入口地址
  • 电子商务网站建设需求分析的物app
  • 西昌市做网站的公司wordpress 链接管理员
  • 建个网站在哪备案重庆网站建设多少钱
  • 龙华区住房和建设局网站是哪个安装wordpress 建立数据库连接时出错
  • 免费com域名注册网站个人推广平台
  • 东台做网站找哪家好腾讯广告投放推广平台价格