欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

go xorm框架的使用

程序员文章站 2022-06-18 07:55:22
一、创建数据库连接xorm支持单引擎和多引擎,多引擎的场景对于初学者来说,没有必要考虑,所以我们主要学习的是单引擎的数据库连接,为了方便检查sql,需要启用打印功能,默认不开启二、操作mysql数据库...

一、创建数据库连接

xorm支持单引擎和多引擎,多引擎的场景对于初学者来说,没有必要考虑,所以我们主要学习的是单引擎的数据库连接,为了方便检查sql,需要启用打印功能,默认不开启

二、操作mysql数据库

查询

建表语句

struct结构体

student.go

grade.go

1、get方法

get方法用于获取单条数据,如:

结合where查询 ,写法很多,主要是刚入门,都可以尝试一下。最终的实现都是一个意思

结构体中已有的非空数据查询

has返回一个boolean类型,表明数据是否存在,err接收如果在查询中产生的错误

2、exist方法

exist方法用于判断数据是否存在,get方法是以id字段举例,那么现在就以name字段举例

下面的写法也很怪异,猜测着去写,很多东西都可以拓展开,刚入门,看啥都很神奇,随便举几个例子,后面慢慢的去尝试

3、find方法

find方法用于查询多条数据 ,find方法的第一个参数为slice的指针或map指针,即为查询后返回的结果,第二个参数可选,为查询的条件struct的指针。

查询时可以加入各种条件,也可以不加。不加时err := engine.find(&stus)查询所有,如果只选择单个字段,也可使用非结构体的slice

4、join方法

第一个参数为连接类型,当前支持inner, left outer, cross中的一个值, 第二个参数为string类型的表名,表对应的结构体指针或者为两个值的[]string,表示表名和别名, 第三个参数为关联键。

每个学生只在一个班级出现,所以对应的结构体应该加上xorm的index标记

如果我们想查询出两张表的具体数据,还需要借助xorm的extend关键字,类似于java中的vo,而extend关键字的用处就是读取的数据引用到struct,结构体中extends标记对应的结构顺序应和最终生成sql中对应的表出现的顺序相同。

因为查询到的数据格式时数组,如果想获取查询出的数据,可以采取循环数组的方式去遍历

或者通过下标去操作stu[0]去获取学生的信息

5、iterate方法

iterate方法提供逐条执行查询到的记录的方法,它所能使用的条件和find方法完全相同

6、count方法

统计数据使用count方法,count方法的参数为struct的指针并且成为查询条件。

7、rows方法

rows方法和iterate方法类似,提供逐条执行查询到的记录的方法,不过rows更加灵活好用。

插入

created可以让您在数据插入到数据库时自动将对应的字段设置为当前时间

engine.tzlocation, _ = time.loadlocation("asia/shanghai") 改变xorm的时区

更新

删除

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框架简单的使用,慢慢学习,慢慢进步,加油少年!相信自己,本文章内容可以参考文档

以上就是go xorm框架的使用的详细内容,更多关于go xorm框架的资料请关注其它相关文章!

相关标签: go xorm