gorm使用小结
增
db.Create(user)
db.Save(user)
参数只能用**结构体指针****,因为要根据指针写入该条插入的数据,
所以user可以作为该条数据使用。
新增只能用结构体
save方法在没有主键的时候是新增,有主键的时候是更新,save可以解决空字段问题。
可以使用 db.NewRecord()判断,该方法只检查 结构体对应数据表 的主键是否为空,不查表。
删
db.Delete(&User{})
改
db.Modle(&User{}).Update()
db.Modle(&User{}).Updates()
1.Modle可以传入&user, 得到的是 已修改 字段的struct,其他字段是默认字段,
2.map类型只能更新到外层(里层指针类型的字段会被置为空),嵌套的struct要解析到struct上去更新。
update更新单列,Update("name","wl")或者当Updates用。
updates可以传入map/struct。
struct只更新非零值的字段。
map的key可以是struct的key,也可以是数据表列名。
map的value要对应struct的类型,比如map[string]interface{}{"updated_at": time.Now()},不能使用字符串。
查
db.First(&user)
db.Last(&user)
db.Take(&user)
db.Find(&users) users := make([]User, 0)
db.Scan()
结果放入另一个struct
db.Pluck("name", &names) names := make([]stirng, 0)
单个字段的slice
查询条件可以在Where中增加,也可以内联,First(&user, "id=?", 1)
其他
gorm的增删改查是 链式方法,每次返回*gorm.DB,即可任意拼接。
db.Table("users") 或者 db.Modle(&User{}) 指定表名
db.Where("name=?", name)
示例
查询结果为一个数字时要用struct来接收
type Amount struct { Total float64 }
amount := Amount{}
db.Select("SUM(price) AS total").Scan(&amount)
更新设置NULL
struct是指针类型,Update("deleted_at", nil)
否则 Update("name", gorm.Expr("NULL))
Updates(map[string]interface{}{"name": gorm.Expr("NULL")})
类型
gorm: bool, time必须是对应的类型,mysql则可以是0, 1 和字符串。
gorm 类型对不上则会使用对应struct的零值。
时区
创建记录时:
必须要是time类型,会根据时区来确定插入的数据时间。
go时间 go时区 数据库存储时间 数据库显示时间
2019-12-01 08:00:00 +8:00 2019-12-01 00:00:00 UTC 2019-12-01 08:00:00
2019-12-01 08:00:00 +0:00 2019-12-01 08:00:00 UTC 2019-12-01 16:00:00

查询时:
1.可以用Where("updated_at < ?", "2019-12-01");
2.时区不影响查询,只将时间部分作为本地时间进行查询。
gorm使用小结的更多相关文章
- Gorm 预加载及输出处理(一)- 预加载应用
单条关联查询 先创建两个关联模型: // 用户模型 type User struct { gorm.Model Username string `gorm:"type:varchar(20) ...
- Gorm 预加载及输出处理(二)- 查询输出处理
上一篇<Gorm 预加载及输出处理(一)- 预加载应用>中留下的三个问题: 如何自定义输出结构,只输出指定字段? 如何自定义字段名,并去掉空值字段? 如何自定义时间格式? 这一篇先解决前两 ...
- Gorm 预加载及输出处理(三)- 自定义时间格式
前言 Gorm 中 time.Time 类型的字段在 JSON 序列化后呈现的格式为 "2020-03-11T18:26:13+08:00",在 Go 标准库文档 - time 的 ...
- [系列] Go - 基于 GORM 获取当前请求所执行的 SQL 信息
前言 为了便于精准排查问题,需要将当前的请求信息与当前执行的 SQL 信息设置对应关系记录下来,记录的 SQL 信息包括: 执行 SQL 的当前时间: 执行 SQL 的文件地址和行号: 执行 SQL ...
- 从零开始编写自己的C#框架(26)——小结
一直想写个总结,不过实在太忙了,所以一直拖啊拖啊,拖到现在,不过也好,有了这段时间的沉淀,发现自己又有了小小的进步.哈哈...... 原想框架开发的相关开发步骤.文档.代码.功能.部署等都简单的讲过了 ...
- Python自然语言处理工具小结
Python自然语言处理工具小结 作者:白宁超 2016年11月21日21:45:26 目录 [Python NLP]干货!详述Python NLTK下如何使用stanford NLP工具包(1) [ ...
- java单向加密算法小结(2)--MD5哈希算法
上一篇文章整理了Base64算法的相关知识,严格来说,Base64只能算是一种编码方式而非加密算法,这一篇要说的MD5,其实也不算是加密算法,而是一种哈希算法,即将目标文本转化为固定长度,不可逆的字符 ...
- iOS--->微信支付小结
iOS--->微信支付小结 说起支付,除了支付宝支付之外,微信支付也是我们三方支付中最重要的方式之一,承接上面总结的支付宝,接下来把微信支付也总结了一下 ***那么首先还是由公司去创建并申请使用 ...
- iOS 之UITextFiled/UITextView小结
一:编辑被键盘遮挡的问题 参考自:http://blog.csdn.net/windkisshao/article/details/21398521 1.自定方法 ,用于移动视图 -(void)mov ...
- K近邻法(KNN)原理小结
K近邻法(k-nearst neighbors,KNN)是一种很基本的机器学习方法了,在我们平常的生活中也会不自主的应用.比如,我们判断一个人的人品,只需要观察他来往最密切的几个人的人品好坏就可以得出 ...
随机推荐
- Spring Bean 的一生
Spring Bean 的一生包括其从创建到消亡的整个过程: 实例创建 => 填充 => 初始化 => 使用 => 销毁. 这里需要注意的是,从 bean 实例的创建到可以使用 ...
- #期望,树的直径#51nod 1803 森林直径
题目 有一棵 \(n\) 个结点的树,按顺序给出树边 \((fa[i],i)\), \(Q\) 次询问查询如果只选取第 \([l,r]\) 条树边,问森林的直径 \(fa[i]\) 的生成方式为 \( ...
- Jetty的ssl模块
启用ssl模块,执行如下命令: java -jar $JETTY_HOME/start.jar --add-modules=ssl 命令的输出,如下: INFO : ssl initialized i ...
- JDK12的新特性:CompactNumberFormat
目录 简介 CompactNumberFormat详解 自定义CompactNumberFormat 解析CompactNumber 总结 JDK12的新特性:CompactNumberFormat ...
- [一本通1681]统计方案 题解(Meet in mid与逆元的结合)
题目描述 小\(B\)写了一个程序,随机生成了\(n\)个正整数,分别是\(a[1]-a[n]\),他取出了其中一些数,并把它们乘起来之后模\(p\),得到了余数\(c\).但是没过多久,小\(B\) ...
- 深入理解 Java 循环结构:while、do while、for 和 for-each 循环
Java 循环 循环可以执行一个代码块,只要达到指定的条件.循环很方便,因为它们节省时间,减少错误,并使代码更易读. Java While 循环 while 循环会循环执行一个代码块,只要指定的条件为 ...
- win10上鼠标右键怎么进入cmd
背景: 在win7上有个很好的功能,在文件夹空白区域,按住 " ctrl + 鼠标右键 " 可以直接打开 cmd 窗口 但是在win10上同样的操作方法,打开的窗口却是 power ...
- 编译安装openGauss 3.0.0
编译安装 openGauss 3.0.0 环境检查 1.1 检查 OS 版本 openGauss支持的操作系统: CentOS 7.6(x86 架构) openEuler-20.03-LTS(aarc ...
- Linux之网络排错
Linux 网卡收包流程如下 网卡收到数据包 将数据包从网卡硬件缓存移动到服务器内存中(DMA方式,不经过CPU) 通过硬中断通知CPU处理 CPU通过软中断通知内核处理 经过TCP/IP协议栈处理 ...
- mysql 必知必会整理—事务[十六]
前言 简单整理一下事务. 正文 并非所有引擎都支持事务处理 正如第21章所述,MySQL支持几种基本的数据库引擎. 正如本章所述,并非所有引擎都支持明确的事务处理管理. MyISAM和InnoDB是两 ...