golang中xorm的基本使用说明
来源:脚本之家
2022-12-31 12:16:17
0浏览
收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《golang中xorm的基本使用说明》,聊聊xorm,我们一起来看看吧!
简单的用法
package main
import (
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
"log"
)
//定义结构体(xorm支持双向映射)
type User struct {
User_id int64 `xorm:"pk autoincr"` //指定主键并自增
Name string `xorm:"unique"` //唯一的
Balance float64
Time int64 `xorm:"updated"` //修改后自动更新时间
Creat_time int64 `xorm:"created"` //创建时间
//Version int `xorm:"version"` //乐观锁
}
//定义orm引擎
var x *xorm.Engine
//创建orm引擎
func init() {
var err error
x, err = xorm.NewEngine("mysql", "root:root@tcp(127.0.0.1:3306)/xorm?charset=utf8")
if err != nil {
log.Fatal("数据库连接失败:", err)
}
if err := x.Sync(new(User)); err != nil {
log.Fatal("数据表同步失败:", err)
}
}
//增
func Insert(name string, balance float64) (int64, bool) {
user := new(User)
user.Name = name
user.Balance = balance
affected, err := x.Insert(user)
if err != nil {
return affected, false
}
return affected, true
}
//删
func Del(id int64) {
user := new(User)
x.Id(id).Delete(user)
}
//改
func update(id int64, user *User) bool {
affected, err := x.ID(id).Update(user)
if err != nil {
log.Fatal("错误:", err)
}
if affected == 0 {
return false
}
return true
}
//查
func getinfo(id int64) *User {
user := &User{User_id: id}
is, _ := x.Get(user)
if !is {
log.Fatal("搜索结果不存在!")
}
return user
}
在gin中的用法
package main
import (
"github.com/gin-gonic/gin"
"./models"
"strconv"
)
//添加操作
func insert(c *gin.Context) {
name := c.Query("name")
if name == "" {
c.JSON(200, gin.H{"msg": "name不得为空!"})
return
}
money := c.Query("money")
if money == "" {
c.JSON(200, gin.H{"msg": "money不得为空!"})
return
}
Balance, _ := strconv.ParseFloat(money, 64)
//添加
user := models.User{}
user.Name = name
user.Balance = Balance
rel, err := models.X.Insert(user)
if rel == 0 || err != nil {
c.JSON(200, gin.H{"msg": "添加错误", "err": err, "rel": rel})
} else {
c.JSON(200, gin.H{"msg": "添加成功"})
}
}
//查询单个操作
func get(c *gin.Context) {
id := c.Query("id")
if id == "" {
c.JSON(200, gin.H{"msg": "id不得为空!"})
return
}
//string转int64
ids, _ := strconv.ParseInt(id, 10, 64)
//查询1
//user := &User{User_id: ids}
//rel, err := models.X.Get(user)
//查询2
user := &models.User{}
rel, err := models.X.Where("user_id = ?", ids).Get(user)
if !rel || err != nil {
c.JSON(200, gin.H{"msg": "查询错误"})
} else {
c.JSON(200, gin.H{"user": user})
}
}
//查询多条操作
func find(c *gin.Context) {
users := make(map[int64]models.User)
err := models.X.Find(&users)
if err != nil {
c.JSON(200, gin.H{"msg": err})
}
c.JSON(200, gin.H{"msg": users})
}
//修改操作
func updates(c *gin.Context) {
id := c.Query("id")
if id == "" {
c.JSON(200, gin.H{"msg": "id1不得为空!", "id": id})
return
}
ids, _ := strconv.ParseInt(id, 10, 64)
name := c.Query("name")
if name == "" {
c.JSON(200, gin.H{"msg": "name不得为空!"})
return
}
balance := c.Query("balance")
if balance == "" {
c.JSON(200, gin.H{"msg": "balance不得为空!"})
return
}
money, _ := strconv.ParseFloat(balance, 64)
//修改
user := models.User{}
user.Name = name
user.Balance = money
rel, err := models.X.Id(ids).Update(user)
if rel == 0 || err != nil {
c.JSON(200, gin.H{"msg": "修改错误!", "rel": rel, "err": err, "user": user})
} else {
c.JSON(200, gin.H{"mag": "修改成功"})
}
}
//删除操作
func delte(c *gin.Context) {
id := c.Query("id")
if id == "" {
c.JSON(200, gin.H{"msg": "id1不得为空!", "id": id})
return
}
//string转化int64
ids, _ := strconv.ParseInt(id, 10, 64)
//删除
user := models.User{}
rel, err := models.X.Id(ids).Delete(user)
if rel == 0 || err != nil {
c.JSON(200, gin.H{"msg": "删除错误!", "rel": rel, "err": err, "user": user})
} else {
c.JSON(200, gin.H{"mag": "删除成功"})
}
}
//事务的提交以及回滚
func gun(c *gin.Context) {
//创建session
session := models.X.NewSession()
defer session.Close()
//创建事务
err := session.Begin()
if err != nil {
c.JSON(200, gin.H{"err": err})
return
}
//操作事务,失败并回滚(模拟购物车结算情景)
car_id := c.Query("car_id")
if car_id == "" {
c.JSON(200, gin.H{"msg": "car_id1不得为空!", "car_id": car_id})
return
}
//查找购物车中的商品id
ids, _ := strconv.ParseInt(car_id, 10, 64)
car := &models.Car{Car_id: ids}
models.X.Get(car)
/**
* goods表库存减去销量
*/
//查询商品
goods := &models.Goods{Goods_id: car.Goods_id}
models.X.Get(goods)
//更新库存
good := models.Goods{}
good.Stock = goods.Stock - car.Num
rel4, err4 := session.ID(car.Goods_id).Update(good)
if rel4 == 0 || err4 != nil {
session.Rollback()
c.JSON(200, gin.H{"err4": err4, "rel4": rel4, "carid": car.Goods_id, "goodsid": goods.Goods_id, "Stock": good.Stock})
return
}
/**
* 用户扣费
*/
//查询用户
user := &models.User{User_id: car.User_id}
models.X.Get(user)
//更新价格
user_up := models.User{}
user_up.Balance = user.Balance - car.Total_price
rel1, err1 := session.ID(car.User_id).Update(user_up)
if err1 != nil || rel1 == 0 {
session.Rollback()
c.JSON(200, gin.H{"err1": err1, "rel1": rel1})
return
}
/**
* 删除用户的购物车信息
*/
rel2, err2 := session.Delete(car)
if err2 != nil || rel2 == 0 {
session.Rollback()
c.JSON(200, gin.H{"err2": err2, "rel2": rel2})
return
}
if user_up.Balance
<p><img alt="" src="/uploads/20221231/167246100963afbad11348d.jpg"></p>
<p>需要填坑的是:这里面我使用事务一直实现不了回滚,再次细致阅读文档才发现,</p>
<p>而关于innodb的设置方法,这里有一个很好的教程 <a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq6ycKaUbJ1rsdDWoYKGfNrGoYeUhJWqspytnJrEeYWqsqN5qX59nK-x0M5oloWEz62tfs6Sqrlph6pxYLyGm2S_fYGofmuDorLN0WyDhp_Rsa6VzoXdsqWGvX1iu6ybcQ' rel='nofollow'>//www.jb51.net/article/202470.htm</a></p>
<p><strong>补充:golang xorm MSSQL where查询案例</strong></p>
<p>xorm官方中文文档 参考 <a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXpusdyfbJZlgdmwoZ3ahJW2r5GZfaarq32errKGm4qNimyyp7ikg4aJ0LGedpeR0LGyh7qXZbF5ha6za4WqfWuOab7dwKKDg3Si' rel='nofollow'>http://xorm.io/docs/</a></p>
<h3>以sqlserver为例</h3>
<p>先初始化连接等...</p>
<pre class="brush:sql;">
engine, err := xorm.NewEngine("mssql", "server=127.0.0.1;user id=sa;password=123456;database=dbname")
//控制台打印SQL语句
engine.ShowSQL(true)
if err != nil {
fmt.Println(err)
}
defer engine.Close()
一、查询案例
ids := []model.MsIdcaid{} //实体定义的话自己写
engine.Cols("Id", "Address").Where("id in(2,3,4,5,6)").OrderBy("id desc,address asc").Find(&ids)
//[SQL] SELECT "Id", "Address" FROM "cdsgus" WHERE (id in(2,3,4,5,6)) ORDER BY id desc,address asc
或者直接自己写SQL
engine.SQL("SELECT Address from cdsgus where id in (2,3,4,6) order by id desc ").Find(&ids)
//[SQL] SELECT Address from cdsgus where id in (2,3,4,6) order by id desc
二、分页查询
方式一 :用Limit(int i,int j) 方法, i=要取的条数, j=开始的位置
MSSQL 虽然执行的结果正确,可以看到生成的分页SQL很乱,建议直接MSSQL分页直接用方式二写在SQL里。其他数据库应该是没有问题, 如:mysql
其实本文用数据库的版本SQL2014 是支持:OFFSET 2 ROW FETCH NEXT 10 ROW ONLY的写法的,xorm并未识别数据库的版本调整分页SQL
engine.Cols("Id", "Name").Where("id in(2,3,4,5,6)").OrderBy("id desc,address asc").Limit(10, 2).Find(&ids)
//[[SQL] SELECT TOP 10 "Id", "Name" FROM "cdsgus" WHERE (id in(2,3,4,5,6)) AND (id NOT IN (SELECT TOP 2 id FROM "cdsgus" WHERE (id in(2,3,4,5,6)) ORDER BY id desc,address asc)) ORDER BY id desc,address asc
方式二 :用原生的SQL方法 ,很妥
engine.SQL("SELECT Id,Name from cdsgus where id in (2,3,4,5,6) order by id desc OFFSET 2 ROW FETCH NEXT 10 ROW ONLY").Find(&ids)
//[SQL] SELECT Id,Name from cdsgus where id in (2,3,4,5,6) order by id desc OFFSET 2 ROW FETCH NEXT 10 ROW ONLY
方式三 :用原生的SQL + Limit 方法 ??MSSQL居然是错误SQL&结果
engine.Sql("SELECT Id,Name from cdsgus where id in (2,3,4,5,6) ").OrderBy("id").Limit(10, 2).Find(&ids)
//[SQL] SELECT Id,Name from cdsgus where id in (2,3,4,5,6)
data, _ := engine.Sql("SELECT Id,Name from cdsgus where id in (2,3,4,5,6) ").OrderBy("id").Limit(10, 2).Query()
//[SQL] SELECT Id,Name from cdsgus where id in (2,3,4,5,6)
方式四 : github.com/go-xorm/builder
以上为个人经验,希望能给大家一个参考,也希望大家多多支持golang学习网。如有错误或未考虑完全的地方,望不吝赐教。
文中关于golang的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《golang中xorm的基本使用说明》文章吧,也可关注golang学习网公众号了解相关技术文章。
版本声明
本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
golang gorm多条件筛选查询操作
- 上一篇
- golang gorm多条件筛选查询操作
- 下一篇
- 解决goxorm无法更新值为默认值的问题
查看更多
最新文章
-
- Golang · Go教程 | 2小时前 | 格式化输出 printf fmt库 格式化动词 Stringer接口
- Golangfmt库用法与格式化技巧解析
- 140浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Golang配置Protobuf安装教程
- 147浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Golang中介者模式实现与通信解耦技巧
- 378浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Golang多协程通信技巧分享
- 255浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Golang如何判断变量类型?
- 393浏览 收藏
-
- Golang · Go教程 | 2小时前 |
- Golang云原生微服务实战教程
- 310浏览 收藏
-
- Golang · Go教程 | 3小时前 |
- Golang迭代器与懒加载结合应用
- 110浏览 收藏
-
- Golang · Go教程 | 3小时前 | 性能优化 并发安全 Golangslicemap 预设容量 指针拷贝
- Golangslicemap优化技巧分享
- 412浏览 收藏
-
- Golang · Go教程 | 3小时前 |
- Golang代理模式与访问控制实现解析
- 423浏览 收藏
-
- Golang · Go教程 | 4小时前 |
- Golang事件管理模块实现教程
- 274浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3163次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3375次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3403次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4506次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3784次使用
查看更多
相关文章
-
- 在golang xorm中使用postgresql的json,array类型的操作
- 2022-12-24 162浏览
-
- golang xorm及time.Time自定义解决json日期格式的问题
- 2022-12-31 127浏览
-
- golang xorm日志写入文件中的操作
- 2023-01-19 305浏览
-
- xorm 一张表,两个字段,关联另外一张表 怎么处理,怎么给字段加别名?
- 2023-01-16 439浏览
-
- 一款golang style语法的golang orm库
- 2023-01-18 466浏览

