golang gorm增删改查db.Model db.Where db.Table
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相关推荐
- gorm增删改查总结
gorm在创建表时使用CreateTable方法进行处理,其参数可以是结构体变量的地址形式,也可以是结构体的地址形式. 例如: var t Tecent db.CreateTable(&t)或 ...
- Django增删改查--图书管理系统
一对一 出版社信息的增删改查 一对多 出版社信息与书籍信息的增删改查 多对多 书籍信息与作者信息的增删改查 建表 from django.db import modelsclass ...
- PHP连接数据库MySQL打造xxx管理系统,实现简单的增删改查功能
目录 前言 概述 内容 创建数据库表 实现列表 新增用户 删除用户 编辑用户 前言 最近刚学完PHP和Mysql,历时半个多月时间完成了这样一个简单的算是人员管理系统吧,为了加深印象总结一下,还有很多 ...
- crmeb从创建数据表到实现最基础增删改查的实现全过程【带附件】
很多使用了 CRMEB 单商户系统的童鞋在进行二开的时候,都会遇到新建了数据表之后不知道对数据表怎么进行操作.那么,这篇文章将带你完整的实现一遍,以后就不会怕啦. 创建数据表 就以最简单的为例,创建一 ...
- mysql 原生 添加数据_手撸Mysql原生语句--增删改查
mysql数据库的增删改查有以下的几种的情况, 1.DDL语句 数据库定义语言: 数据库.表.视图.索引.存储过程,例如CREATE DROP ALTER SHOW 2.DML语句 数据库操纵语言: ...
- java里SQL insert操作的语法_Java含个人总结语法:JDBC,学生表,实体类,集合,增删改查,注入,预处理【诗书画唱】...
create table denglu( uname varchar(30), upwd varchar(30) ) insert into denglu values('诗书','123') ins ...
- Golang原生sql操作Mysql数据库增删改查
Golang要操作mysql数据库,首先需要在当期系统配置GOPATH,因为需要使用go get命令把驱动包下载到GOPATH下使用. 首先配置好你的GOPATH,执行以下命令,下载安装mysql驱动 ...
- golang连接mysql操作示例增删改查
golang本身没有提供连接mysql的驱动,但是定义了标准接口供第三方开发驱动.这里连接mysql可以使用第三方库,第三方库推荐使用https://github.com/Go-SQL-Driver/ ...
- PHP:ThinkPHP5数据库操作增删改查-Model类
1.Model的命名规范 一般model的名字和表名是对应的,例如 表名 pre_user -> 模型名 User.php User 表名 pre_user_info -> 模型名 Use ...
最新文章
- 【Android】OpenGL ES for Android 教程1 - HelloWorld
- Httpd之检测与安装
- SSM中实现CRUD并配置输出sql语句
- python try catch 能知道是哪一行代码_能导致3.7亿美元损失的异常,到底是怎么回事?...
- 升级到php7和安装拓展(mac centos)
- 前端防抖和节流合二为一
- Git学习系列(七)Bug和Feature分支管理详解
- 计算机毕业设计中JAVA 23种开发模式详解(代码举例)
- 蓝桥杯2020年第十一届Python省赛第五题-排序
- python实现对解析之后的DOM进行层次化处理升序输出
- pandas时间序列空值填充
- RICOH 身份证 便捷打印
- excel多元线性拟合_多元线性回归EXCEL图表
- 360P2建html网站,如何自己建网站
- axios+springboot 报错 POST http://localhost:8080/Login 404 (Not Found)
- C# Dev利用TreeList设置菜单导航并双击节点打开模块窗体
- 学微积,用手机,人人“知识共享”学真知
- 30分钟教你写出10分的淘宝标题
- flask开启debug调试模式
- 计算机的内存的作用是什么,电脑内存的作用是什么?