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

Gorm简单了解

GORM 指南 | GORM - The fantastic ORM library for Golang, aims to be developer friendly.

04_GORM查询操作_哔哩哔哩_bilibili

前置:

db调用操作语句中间加debug()可以显示对应的sql语句

1.Gorm模型定义(理解重点)

02_GORM模型定义那些事儿_哔哩哔哩_bilibili

模型定义 | GORM - The fantastic ORM library for Golang, aims to be developer friendly.

 1)

2)结构体可以指定tag对应到数据库里的字段名称

3)一些tag

4)默认ID作主键,也可以用tag指定

 5)表名,默认结构体名字+s,可以指定

可以用func TableName()返回指定表名或者Table()

6)列名

7)三个时间戳标签

有model的就会自动嵌入,专门记录创建修改和删除的时间戳。

软删除:DeletedAt设置为当前时间表示软删除,并不是真正删除数据,相当于保护了数据完整性。查询来的时候会发现DeletedAt有值默认逻辑删除了

2.数据库连接

获取一个db代表这个数据库,后续可以利用db进行数据库操作

3.迁移表

 会自动把传入的数据类型与数据库的表格对应起来,如果有结构体变化会更改表格结构。

gorm模型和表格对应关系 

4.增添

Create()传入结构体和结构体指针都可以,但是一般指针比较小。

NewRecord()判断主键对应的对象是否已经在数据库里存在,会造成冲突

1)默认值

结构体后面反引号`gorm:"default:‘xxx’ " `

5.删除

1)单个删除或者全删

删除该类型对应表里和主键id一样的记录

tips:警告删除记录时,请确保主键字段有值,GORM 会通过主键去删除记录,如果主键为空,GORM会删除该model的所有记录。

2)符合条件的批量删除

3)软删除

 4)物理删除

6.修改

1)更新所有字段

2)改指定字段

update和updates的区别是更新一个还是多个字段

3)更新或忽略某些字段 

7.查找

1)一般

为什么传地址?因为你要查询出结果,查询结果会放在传进去的参数里,而不是放返回值里。

而且这一条只限于主键id为int类型的才能获取。               

这里传入的是一个slice指针,获取一组数据 

db.First(&user, 10)
// SELECT * FROM users WHERE id = 10;db.First(&user, "10")
// SELECT * FROM users WHERE id = 10;db.Find(&users, []int{1,2,3})
// SELECT * FROM users WHERE id IN (1,2,3);// 获取第一条记录(主键升序)
db.First(&user)
// SELECT * FROM users ORDER BY id LIMIT 1;// 获取一条记录,没有指定排序字段
db.Take(&user)
// SELECT * FROM users LIMIT 1;// 获取最后一条记录(主键降序)
db.Last(&user)
// SELECT * FROM users ORDER BY id DESC LIMIT 1// Get all records
result := db.Find(&users)

2)where

查询 | GORM - The fantastic ORM library for Golang, aims to be developer friendly.

 都是在查询前面插入一个where函数写条件

// Get first matched record
db.Where("name = ?", "jinzhu").First(&user)
// SELECT * FROM users WHERE name = 'jinzhu' ORDER BY id LIMIT 1;// Get all matched records
db.Where("name <> ?", "jinzhu").Find(&users)
// SELECT * FROM users WHERE name <> 'jinzhu';// IN
db.Where("name IN ?", []string{"jinzhu", "jinzhu 2"}).Find(&users)
// SELECT * FROM users WHERE name IN ('jinzhu','jinzhu 2');// LIKE
db.Where("name LIKE ?", "%jin%").Find(&users)
// SELECT * FROM users WHERE name LIKE '%jin%';// AND
db.Where("name = ? AND age >= ?", "jinzhu", "22").Find(&users)
// SELECT * FROM users WHERE name = 'jinzhu' AND age >= 22;// Time
db.Where("updated_at > ?", lastWeek).Find(&users)
// SELECT * FROM users WHERE updated_at > '2000-01-01 00:00:00';// BETWEEN
db.Where("created_at BETWEEN ? AND ?", lastWeek, today).Find(&users)
// SELECT * FROM users WHERE created_at BETWEEN '2000-01-01 00:00:00' AND '2000-01-08 00:00:00';

 

http://www.lryc.cn/news/151202.html

相关文章:

  • 第一百三十三回 StreamProvier
  • java 多个list取交集
  • 文件上传与下载
  • SpringBoot 整合 RabbitMQ
  • 气象科普丨气象站的分类与应用
  • 【论文精读】Learning Transferable Visual Models From Natural Language Supervision
  • 缓存和分布式锁笔记
  • React笔记(七)Antd
  • 无涯教程-Android - RadioButton函数
  • kafka如何避免消费组重平衡
  • 浅谈一下企业信息化管理
  • 北京APP外包开发团队人员构成
  • Node基础and包管理工具
  • 【python使用 Pillow 库】缩小|放大图片
  • 解决Ubuntu 或Debian apt-get IPv6问题:如何设置仅使用IPv4
  • Xubuntu16.04系统中解决无法识别exFAT格式的U盘
  • Pygame中Trivia游戏解析6-1
  • idea中创建springboot项目显示Spring Initializr Error
  • VScode 国内下载源 以及 nvm版本控制器下载与使用
  • GO|经典错误之回车与\n
  • 【MATLAB第71期】基于MATLAB的Abcboost自适应决策树多输入单输出回归预测及多分类预测模型(更新中)
  • ARM编程模型-内存空间和数据
  • leetcode原题: 最大数
  • docker 是什么
  • 基于Gin框架的HTTP接口限速实践
  • WSL中为Ubuntu和Debian设置固定IP的终极指南
  • axios+vite配置反向代理踩坑记录
  • Spring IOC的理解
  • 2023年京东箱包行业数据分析(京东数据运营)
  • 对称加密 非对称加密 AC认证 https原理