go xorm框架的使用
本篇文章给大家分享《go xorm框架的使用》,覆盖了Golang的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
一、创建数据库连接
xorm支持单引擎和多引擎,多引擎的场景对于初学者来说,没有必要考虑,所以我们主要学习的是单引擎的数据库连接,为了方便检查SQL,需要启用打印功能,默认不开启
var engine *xorm.Engine
func main() {
var err error
engine, err = xorm.NewEngine("mysql", "root:123456@tcp(127.0.0.1:3306)/myschool?charset=utf8")
if err != nil {
log.Println(err)
}
// 控制台打印出生成的SQL语句
engine.ShowSQL(true)
}
二、操作mysql数据库
查询
建表语句
CREATE TABLE `student` ( `id` varchar(225) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL, `name` varchar(225) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `age` int(11) NULL DEFAULT NULL, `gradeid` int(11) NULL DEFAULT NULL, PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic; CREATE TABLE `grade` ( `id` int(11) NOT NULL AUTO_INCREMENT, `gradename` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL, PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
struct结构体
student.go
type Student struct {
Id string `orm:"id,primary" json:"id"`
Name string `orm:"name" json:"name"`
Age int `orm:"age" json:"age"`
Gradeid int `orm:"gradeid" json:"gradeid"`
}
grade.go
type Grade struct {
Id int `orm:"id,primary" json:"id"`
Gradename string `orm:"gradename" json:"gradename"`
}
1、Get方法
Get方法用于获取单条数据,如:
结合Where查询 ,写法很多,主要是刚入门,都可以尝试一下。最终的实现都是一个意思
var stu student.Student
has, err := engine.Where("id=?", "1").Get(&stu)
stu := new(student.Student)
has, err := engine.Where("id=?", "1").Get(stu)
stu := student.Student{}
has, err := engine.Where("id=?", "1").Get(&stu)
stu := &student.Student{}
has, err := engine.Where("id=?", "1").Get(stu)
if err != nil {
log.Println(err)
}
log.Println("是否存在:",has)
log.Println(stu)
结构体中已有的非空数据查询
stu := &student.Student{Id:"1"}
has, err := engine.Get(stu)
if err != nil {
log.Println(err)
}
log.Println("是否存在:",has)
log.Println(stu)
has返回一个boolean类型,表明数据是否存在,err接收如果在查询中产生的错误
2、Exist方法
Exist方法用于判断数据是否存在,Get方法是以id字段举例,那么现在就以name字段举例
下面的写法也很怪异,猜测着去写,很多东西都可以拓展开,刚入门,看啥都很神奇,随便举几个例子,后面慢慢的去尝试
has, err := engine.Where("name=?", "少杰").Exist(&student.Student{})
has, err := engine.Table(&student.Student{}).Where("name=?", "少杰").Exist()
has, err := engine.Exist(&student.Student{Name: "少杰"})
if err != nil {
log.Println(err)
}
log.Println("是否存在:", has)
3、Find方法
Find方法用于查询多条数据 ,Find方法的第一个参数为slice的指针或Map指针,即为查询后返回的结果,第二个参数可选,为查询的条件struct的指针。
stu := make([]student.Student, 0)
// Cols 查询指定字段
// Limit 分页查询 (显示的条数,从第几个开始)
err := engine.Where("id=?", "1").Cols("name").Limit(10, 0).Find(&stus)
if err != nil {
log.Println(err)
}
log.Println("查询到的信息:", stu)
查询时可以加入各种条件,也可以不加。不加时err := engine.Find(&stus)查询所有,如果只选择单个字段,也可使用非结构体的Slice
var strings []string
// Table 需要操作的表名称
err := engine.Table("student").Cols("id").Find(&strings)
if err != nil {
log.Println(err)
}
log.Println("查询到的信息:",strings)
4、Join方法
第一个参数为连接类型,当前支持INNER, LEFT OUTER, CROSS中的一个值, 第二个参数为string类型的表名,表对应的结构体指针或者为两个值的[]string,表示表名和别名, 第三个参数为关联键。
每个学生只在一个班级出现,所以对应的结构体应该加上xorm的index标记
type Student struct {
Id string `orm:"id,primary" json:"id"`
Name string `orm:"name" json:"name"`
Age int `orm:"age" json:"age"`
Gradeid int `orm:"gradeid" json:"gradeid" xorm:"index"`
}
type Grade struct {
Id int `orm:"id,primary" json:"id"`
Gradename string `orm:"gradename" json:"gradename"`
}
如果我们想查询出两张表的具体数据,还需要借助xorm的extend关键字,类似于java中的vo,而extend关键字的用处就是读取的数据引用到struct,结构体中extends标记对应的结构顺序应和最终生成SQL中对应的表出现的顺序相同。
type Student struct {
modle.Student `xorm:"extends"`
modle.Grade `xorm:"extends"`
}
// 查询年纪时三年纪的学生
stu := make([]Student, 0)
err := engine.Where("gradeid=?", "3").Join("INNER", "grade", "grade.id = student.gradeid").Find(&stu)
if err != nil {
log.Println(err)
}
log.Println("查询到的信息:" , stu)
因为查询到的数据格式时数组,如果想获取查询出的数据,可以采取循环数组的方式去遍历
for _, value := range stu {
log.Println("value:", value)
}
或者通过下标去操作stu[0]去获取学生的信息
5、Iterate方法
Iterate方法提供逐条执行查询到的记录的方法,它所能使用的条件和Find方法完全相同
// Iterate 方法
err := engine.Where("age > ? ", 10).Iterate(new(modle.Student), func(i int, bean interface{}) error {
stu := bean.(*modle.Student)
log.Println("查询到的信息:", stu, i)
return nil
})
6、Count方法
统计数据使用Count方法,Count方法的参数为struct的指针并且成为查询条件。
// Count 判断有几个
stuCount := new(modle.Student)
total, err := engine.Where("age >?", 10).Count(stuCount)
if err != nil {
log.Println(err)
}
log.Println("年龄大于10的有", total, "个")
7、Rows方法
Rows方法和Iterate方法类似,提供逐条执行查询到的记录的方法,不过Rows更加灵活好用。
stu := new(modle.Student)
rows, err := engine.Where("age >?", 10).Rows(stu)
if err != nil {
log.Println(err)
}
defer rows.Close()
for rows.Next() {
err = rows.Scan(stu)
if err != nil {
log.Println(err)
}
log.Println("========", stu)
}
插入
Created可以让您在数据插入到数据库时自动将对应的字段设置为当前时间
engine.TZLocation, _ = time.LoadLocation("Asia/Shanghai") 改变xorm的时区
type Student struct {
Id string `orm:"id,primary" json:"id"`
Name string `orm:"name" json:"name"`
Age int `orm:"age" json:"age"`
Gradeid int `orm:"gradeid" json:"gradeid" xorm:"index"`
CreatedTime time.Time `xorm:"created"`
}
// 创建一个结构体 var stuInsert modle.Student stuInsert.Id = "3" stuInsert.Name = "王五" stuInsert.Age = 20 engine.Insert(&stuInsert)
更新
// 将id=1的用户名称修改为少杰
var stuUpdate modle.Student
stuUpdate.Name = "少杰"
affected, err := engine.Where("id=?", "1").Update(&stuUpdate)
if err != nil {
log.Println(err)
}
log.Println("是否更新成功:", affected)
删除
// 删除一个id=3的学生
var stuDelete modle.Student
affected, err := engine.Where("id=?", "3").Delete(&stuDelete)
if err != nil {
log.Println(err)
}
log.Println("是否删除成功:", affected)
Column属性定义
| name | 当前field对应的字段的名称,可选,如不写,则自动根据field名字和转换规则命名,如与其它关键字冲突,请使用单引号括起来。 |
|---|---|
| pk | 是否是Primary Key,如果在一个struct中有多个字段都使用了此标记,则这多个字段构成了复合主键,单主键当前支持int32,int,int64,uint32,uint,uint64,string这7种Go的数据类型,复合主键支持这7种Go的数据类型的组合。 |
| 当前支持30多种字段类型,详情参见本文最后一个表格 | 字段类型 |
| autoincr | 是否是自增 |
| [not ]null 或 notnull | 是否可以为空 |
| unique或unique(uniquename) | 是否是唯一,如不加括号则该字段不允许重复;如加上括号,则括号中为联合唯一索引的名字,此时如果有另外一个或多个字段和本unique的uniquename相同,则这些uniquename相同的字段组成联合唯一索引 |
| index或index(indexname) | 是否是索引,如不加括号则该字段自身为索引,如加上括号,则括号中为联合索引的名字,此时如果有另外一个或多个字段和本index的indexname相同,则这些indexname相同的字段组成联合索引 |
| extends | 应用于一个匿名成员结构体或者非匿名成员结构体之上,表示此结构体的所有成员也映射到数据库中,extends可加载无限级 |
| - | 这个Field将不进行字段映射 |
| -> | 这个Field将只写入到数据库而不从数据库读取 |
| 这个Field将只从数据库读取,而不写入到数据库 | |
| created | 这个Field将在Insert时自动赋值为当前时间 |
| updated | 这个Field将在Insert或Update时自动赋值为当前时间 |
| deleted | 这个Field将在Delete时设置为当前时间,并且当前记录不删除 |
| version | 这个Field将会在insert时默认为1,每次更新自动加1 |
| default 0或default(0) | 设置默认值,紧跟的内容如果是Varchar等需要加上单引号 |
| json | 表示内容将先转成Json格式,然后存储到数据库中,数据库中的字段类型可以为Text或者二进制 |
| comment | 设置字段的注释(当前仅支持mysql) |
xorm框架简单的使用,慢慢学习,慢慢进步,加油少年!相信自己,本文章内容可以参考文档 http://xorm.topgoer.com/
以上就是《go xorm框架的使用》的详细内容,更多关于golang的资料请关注golang学习网公众号!
go 实现简易端口扫描的示例
- 上一篇
- go 实现简易端口扫描的示例
- 下一篇
- Golang实现AES对称加密的过程详解
-
- Golang · Go教程 | 6分钟前 | golang dockercompose 健康检查 多阶段构建 启动优化
- Golang优化Docker多容器启动技巧
- 228浏览 收藏
-
- Golang · Go教程 | 11分钟前 |
- 优化Golang模块缓存,提升构建效率技巧
- 483浏览 收藏
-
- Golang · Go教程 | 15分钟前 |
- Go递归函数返回值处理方法
- 353浏览 收藏
-
- Golang · Go教程 | 41分钟前 |
- Golang微服务容器化部署指南
- 226浏览 收藏
-
- Golang · Go教程 | 42分钟前 |
- Golang静态资源管理实战指南
- 186浏览 收藏
-
- Golang · Go教程 | 1小时前 | golang 自定义函数 模板渲染 html/template 模板语法
- Golang模板渲染教程与使用详解
- 104浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Go模块版本管理全攻略
- 268浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Golang集成TerraformSDK管理IaC教程
- 175浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Golang表单验证错误解决技巧
- 117浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Golang日志滚动实现技巧
- 183浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- GolangBenchmark优化技巧全解析
- 275浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3179次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3390次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3419次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4525次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3799次使用
-
- 聊聊goxorm生成mysql的结构体问题
- 2022-12-27 162浏览
-
- go语言 xorm框架 postgresql 的用法及详细注解
- 2023-01-27 447浏览
-
- 使用go xorm来操作mysql的方法实例
- 2023-01-25 367浏览

