1. 创建

创建记录:

user := User{Name: "Jinzhu", Age: 18, Birthday: time.Now()}db.NewRecord(user) // => 主键为空返回`true`db.Create(&user)db.NewRecord(user) // => 创建`user`后返回`false`

设置默认值:
可以在gorm tag中定义默认值,然后插入SQL将忽略具有默认值的这些字段,并且其值为空,并且在将记录插入数据库后,gorm将从数据库加载这些字段的值。

type Animal struct {ID   int64Name string `gorm:"default:'galeone'"`Age  int64
}var animal = Animal{Age: 99, Name: ""}
db.Create(&animal)
INSERT INTO animals("age") values('99');
SELECT name from animals WHERE ID=111; // 返回主键为 111
animal.Name => 'galeone'

2. 查询

获取:第一条记录/ 最后一条记录/ 所有记录

// 获取第一条记录,按主键排序
db.First(&user)
 SELECT * FROM users ORDER BY id LIMIT 1;// 获取最后一条记录,按主键排序
db.Last(&user)
 SELECT * FROM users ORDER BY id DESC LIMIT 1;// 获取所有记录
db.Find(&users)
 SELECT * FROM users;// 使用主键获取记录
db.First(&user, 10)
 SELECT * FROM users WHERE id = 10;

Where查询条件

// 获取第一个匹配记录
db.Where("name = ?", "jinzhu").First(&user)
 SELECT * FROM users WHERE name = 'jinzhu' limit 1;// 获取所有匹配记录
db.Where("name = ?", "jinzhu").Find(&users)
 SELECT * FROM users WHERE name = 'jinzhu';
// IN
db.Where("name in (?)", []string{"jinzhu", "jinzhu 2"}).Find(&users)// LIKE
db.Where("name LIKE ?", "%jin%").Find(&users)// AND
db.Where("name = ? AND age >= ?", "jinzhu", "22").Find(&users)

注意:当使用struct查询时,GORM将只查询那些具有值的字段

// Struct
db.Where(&User{Name: "zhangyang", Age: 20}).First(&user)
 SELECT * FROM users WHERE name = "zhangyang" AND age = 20 LIMIT 1;// Map
db.Where(map[string]interface{}{"name": "zhangyang", "age": 20}).Find(&users)
 SELECT * FROM users WHERE name = "zhangyang" AND age = 20;// 主键的Slice
db.Where([]int64{20, 21, 22}).Find(&users)
 SELECT * FROM users WHERE id IN (20, 21, 22);

Not条件查询

db.Not("name", "jinzhu").First(&user)
 SELECT * FROM users WHERE name <> "jinzhu" LIMIT 1;// Not In
db.Not("name", []string{"jinzhu", "jinzhu 2"}).Find(&users)
 SELECT * FROM users WHERE name NOT IN ("jinzhu", "jinzhu 2");// Not In slice of primary keys
db.Not([]int64{1,2,3}).First(&user)
 SELECT * FROM users WHERE id NOT IN (1,2,3);db.Not([]int64{}).First(&user)
 SELECT * FROM users;

Or条件查询

db.Where("role = ?", "admin").Or("role = ?", "super_admin").Find(&users)
 SELECT * FROM users WHERE role = 'admin' OR role = 'super_admin';// Struct
db.Where("name = 'jinzhu'").Or(User{Name: "jinzhu 2"}).Find(&users)
 SELECT * FROM users WHERE name = 'jinzhu' OR name = 'jinzhu 2';

Select 指定要从数据库检索的字段,默认情况下,将选择所有字段;

db.Select("name, age").Find(&users)
 SELECT name, age FROM users;db.Select([]string{"name", "age"}).Find(&users)
 SELECT name, age FROM users;

Order

db.Order("age desc, name").Find(&users)
 SELECT * FROM users ORDER BY age desc, name;// Multiple orders
db.Order("age desc").Order("name").Find(&users)
 SELECT * FROM users ORDER BY age desc, name;// ReOrder 从数据库检索记录时指定顺序,将重排序设置为true以覆盖定义的条件
db.Order("age desc").Find(&users1).Order("age", true).Find(&users2)
 SELECT * FROM users ORDER BY age desc; (users1)
 SELECT * FROM users ORDER BY age; (users2)

Limit , Offset
指定要检索的记录数

db.Limit(3).Find(&users)
 SELECT * FROM users LIMIT 3;

指定在开始返回记录之前要跳过的记录数

db.Offset(3).Find(&users)
 SELECT * FROM users OFFSET 3;// Cancel offset condition with -1
db.Offset(10).Find(&users1).Offset(-1).Find(&users2)
 SELECT * FROM users OFFSET 10; (users1)
 SELECT * FROM users; (users2)

Count,Group & Having,Join
获取记录数

db.Where("name = ?", "jinzhu").Or("name = ?", "jinzhu 2").Find(&users).Count(&count)
 SELECT * from USERS WHERE name = 'jinzhu' OR name = 'jinzhu 2'; (users)
 SELECT count(*) FROM users WHERE name = 'jinzhu' OR name = 'jinzhu 2'; (count)db.Model(&User{}).Where("name = ?", "jinzhu").Count(&count)
 SELECT count(*) FROM users WHERE name = 'jinzhu'; (count)//指定表deleted_users
db.Table("deleted_users").Count(&count)
//
rows, err := db.Table("orders").Select("date(created_at) as date, sum(amount) as total").Group("date(created_at)").Rows()
rows, err := db.Table("users").Select("users.name, emails.email").Joins("left join emails on emails.user_id = users.id").Rows()

3. 更新

更新全部字段
Save将包括执行更新SQL时的所有字段,即使它没有更改

db.First(&user)user.Name = "jinzhu 2"
user.Age = 100
db.Save(&user) UPDATE users SET name='jinzhu 2', age=100, birthday='2016-01-01', updated_at = '2013-11-17 21:34:10' WHERE id=111;

更新指定字段
如果只想更新指定字段,可以使用Update, Updates

// 更新单个属性(如果更改)
db.Model(&user).Update("name", "hello")
 UPDATE users SET name='hello', updated_at='2013-11-17 21:34:10' WHERE id=111;// 使用组合条件更新单个属性
db.Model(&user).Where("active = ?", true).Update("name", "hello")
 UPDATE users SET name='hello', updated_at='2013-11-17 21:34:10' WHERE id=111 AND active=true;// 使用`map`更新多个属性,只会更新这些更改的字段
db.Model(&user).Updates(map[string]interface{}{"name": "hello", "age": 18, "actived": false})
 UPDATE users SET name='hello', age=18, actived=false, updated_at='2013-11-17 21:34:10' WHERE id=111;// 使用`struct`更新多个属性,只会更新这些更改的和非空白字段
db.Model(&user).Updates(User{Name: "hello", Age: 18})
 UPDATE users SET name='hello', age=18, updated_at = '2013-11-17 21:34:10' WHERE id = 111;// 警告:当使用struct更新时,FORM将仅更新具有非空值的字段
// 对于下面的更新,什么都不会更新为"",0,false是其类型的空白值
db.Model(&user).Updates(User{Name: "", Age: 0, Actived: false})

更新选择的字段
如果您只想在更新时更新或忽略某些字段,可以使用Select, Omit

db.Model(&user).Select("name").Updates(map[string]interface{}{"name": "hello", "age": 18, "actived": false})
 UPDATE users SET name='hello', updated_at='2013-11-17 21:34:10' WHERE id=111;db.Model(&user).Omit("name").Updates(map[string]interface{}{"name": "hello", "age": 18, "actived": false})
 UPDATE users SET age=18, actived=false, updated_at='2013-11-17 21:34:10' WHERE id=111;

4. 删除

警告:删除记录时,需要确保其主要字段具有值,GORM将使用主键删除记录,如果主要字段为空,GORM将删除模型的所有记录

// 删除存在的记录
db.Delete(&email)
 DELETE from emails where id=10;// 为Delete语句添加额外的SQL选项
db.Set("gorm:delete_option", "OPTION (OPTIMIZE FOR UNKNOWN)").Delete(&email)
 DELETE from emails where id=10 OPTION (OPTIMIZE FOR UNKNOWN);

批量删除
删除所有匹配记录

db.Where("email LIKE ?", "%jinzhu%").Delete(Email{})
 DELETE from emails where email LIKE "%jinhu%";db.Delete(Email{}, "email LIKE ?", "%jinzhu%")
 DELETE from emails where email LIKE "%jinhu%";

golang gorm增删改查db.Model db.Where db.Table相关推荐

  1. gorm增删改查总结

    gorm在创建表时使用CreateTable方法进行处理,其参数可以是结构体变量的地址形式,也可以是结构体的地址形式. 例如: var t Tecent db.CreateTable(&t)或 ...

  2. Django增删改查--图书管理系统

    一对一     出版社信息的增删改查 一对多    出版社信息与书籍信息的增删改查 多对多    书籍信息与作者信息的增删改查 建表 from django.db import modelsclass ...

  3. PHP连接数据库MySQL打造xxx管理系统,实现简单的增删改查功能

    目录 前言 概述 内容 创建数据库表 实现列表 新增用户 删除用户 编辑用户 前言 最近刚学完PHP和Mysql,历时半个多月时间完成了这样一个简单的算是人员管理系统吧,为了加深印象总结一下,还有很多 ...

  4. crmeb从创建数据表到实现最基础增删改查的实现全过程【带附件】

    很多使用了 CRMEB 单商户系统的童鞋在进行二开的时候,都会遇到新建了数据表之后不知道对数据表怎么进行操作.那么,这篇文章将带你完整的实现一遍,以后就不会怕啦. 创建数据表 就以最简单的为例,创建一 ...

  5. mysql 原生 添加数据_手撸Mysql原生语句--增删改查

    mysql数据库的增删改查有以下的几种的情况, 1.DDL语句 数据库定义语言: 数据库.表.视图.索引.存储过程,例如CREATE DROP ALTER SHOW 2.DML语句 数据库操纵语言: ...

  6. java里SQL insert操作的语法_Java含个人总结语法:JDBC,学生表,实体类,集合,增删改查,注入,预处理【诗书画唱】...

    create table denglu( uname varchar(30), upwd varchar(30) ) insert into denglu values('诗书','123') ins ...

  7. Golang原生sql操作Mysql数据库增删改查

    Golang要操作mysql数据库,首先需要在当期系统配置GOPATH,因为需要使用go get命令把驱动包下载到GOPATH下使用. 首先配置好你的GOPATH,执行以下命令,下载安装mysql驱动 ...

  8. golang连接mysql操作示例增删改查

    golang本身没有提供连接mysql的驱动,但是定义了标准接口供第三方开发驱动.这里连接mysql可以使用第三方库,第三方库推荐使用https://github.com/Go-SQL-Driver/ ...

  9. PHP:ThinkPHP5数据库操作增删改查-Model类

    1.Model的命名规范 一般model的名字和表名是对应的,例如 表名 pre_user -> 模型名 User.php User 表名 pre_user_info -> 模型名 Use ...

最新文章

  1. 【Android】OpenGL ES for Android 教程1 - HelloWorld
  2. Httpd之检测与安装
  3. SSM中实现CRUD并配置输出sql语句
  4. python try catch 能知道是哪一行代码_能导致3.7亿美元损失的异常,到底是怎么回事?...
  5. 升级到php7和安装拓展(mac centos)
  6. 前端防抖和节流合二为一
  7. Git学习系列(七)Bug和Feature分支管理详解
  8. 计算机毕业设计中JAVA 23种开发模式详解(代码举例)
  9. 蓝桥杯2020年第十一届Python省赛第五题-排序
  10. python实现对解析之后的DOM进行层次化处理升序输出
  11. pandas时间序列空值填充
  12. RICOH 身份证 便捷打印
  13. excel多元线性拟合_多元线性回归EXCEL图表
  14. 360P2建html网站,如何自己建网站
  15. axios+springboot 报错 POST http://localhost:8080/Login 404 (Not Found)
  16. C# Dev利用TreeList设置菜单导航并双击节点打开模块窗体
  17. 学微积,用手机,人人“知识共享”学真知
  18. 30分钟教你写出10分的淘宝标题
  19. flask开启debug调试模式
  20. 计算机的内存的作用是什么,电脑内存的作用是什么?

热门文章

  1. Java基础教程带你走进java的世界
  2. Direct3D基础——预备知识:表面
  3. 什么是工业互联网?它从哪里来,要到哪里去?
  4. scapy刺探星巴克无线网,记录顾客信息
  5. 电信运营商的 MBOSS 系统
  6. 彻底颠覆几句话vm_彻底颠覆Web开发:面向移动的设计
  7. Linux运维经典问题33则(附赠年薪10W+面试题与答案)
  8. 区间概念让5千年都无人能识的无穷大自然数一下子暴露出来——数学一直被假自然数集(列)迷惑而将各假N误为N
  9. java如何把汉字转拼音
  10. EasyAR尝鲜系列教程之视频播放功能的实现