xorm表结构操作实例
获取数据库信息
package main
import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
"log"
)
var engine *xorm.Engine
type User struct {
ID int `xorm:"id"`
Name string `xorm:"name"`
}
func main() {
var err error
engine, err = xorm.NewEngine("mysql", "root:123456@/test")
if err != nil {
log.Fatal(err)
return
}
//xorm支持获取表结构信息,通过调用engine.DBMetas()可以获取到数据库中所有的表,字段,索引的信息。
tbs, err := engine.DBMetas()
if err != nil {
log.Fatal(err)
return
}
for i, tb := range tbs {
fmt.Println("index:", i, "tbName", tb.Name)
}
/*输出
index: 0 tbName prefix_user
index: 1 tbName student
*/
//TableInfo()根据传入的结构体指针及其对应的Tag,提取出模型对应的表结构信息。
//这里不是数据库当前的表结构信息,而是我们通过struct建模时希望数据库的表的结构信息
//比如user表的数据库当前有三个属性,但是只会打印出两个属性
tableInfo:=engine.TableInfo(User{})
columns:= tableInfo.Columns()
for i,column := range columns{
fmt.Println("index:",i," columnName:",column.Name)
}
/*輸出:
index: 0 columnName: id
index: 1 columnName: name*/
}
表操作
创建表使用engine.CreateTables(),参数为一个或多个空的对应Struct的指针。
package main import (
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
"log"
) var engine *xorm.Engine type User1 struct {
ID int `xorm:"id"`
Name string `xorm:"name"`
} func main() {
var err error
engine, err = xorm.NewEngine("mysql", "root:123456@/test")
if err != nil {
log.Fatal(err)
return
} //创建表使用engine.CreateTables(),参数为一个或多个空的对应Struct的指针。
err = engine.CreateTables(User1{})
if err != nil {
log.Fatal(err)
return
}
}
IsTableEmpty()判断表是否为空,参数和CreateTables相同
package main import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
"log"
) var engine *xorm.Engine type User1 struct {
ID int `xorm:"id"`
Name string `xorm:"name"`
} func main() {
var err error
engine, err = xorm.NewEngine("mysql", "root:123456@/test")
if err != nil {
log.Fatal(err)
return
} //IsTableEmpty()判断表是否为空,参数和CreateTables相同
re,err := engine.IsTableEmpty(User1{})
if err!=nil {
log.Fatal(err)
return
}
fmt.Println(re)
}
IsTableExist()判断表是否存在,参数和CreateTables相同
package main import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
"log"
) var engine *xorm.Engine type User1 struct {
ID int `xorm:"id"`
Name string `xorm:"name"`
} type User2 struct {
ID int `xorm:"id"`
Name string `xorm:"name"`
} func main() {
var err error
engine, err = xorm.NewEngine("mysql", "root:123456@/test")
if err != nil {
log.Fatal(err)
return
} //IsTableExist()判断表是否存在,参数和CreateTables相同
res,err := engine.IsTableExist(User1{})
if err!=nil {
log.Fatal(err)
return
}
fmt.Println(res)
//user1表之前建立过,所以输出为true res,err = engine.IsTableExist(User2{})
if err!=nil {
log.Fatal(err)
return
}
fmt.Println(res)
//之前没有建立过user2表中,所以输出为false
}
删除表使用engine.DropTables(),参数为一个或多个空的对应Struct的指针或者表的名字。
package main import (
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
"log"
) var engine *xorm.Engine type User1 struct {
ID int `xorm:"id"`
Name string `xorm:"name"`
} type User2 struct {
ID int `xorm:"id"`
Name string `xorm:"name"`
} func main() {
var err error
engine, err = xorm.NewEngine("mysql", "root:123456@/test")
if err != nil {
log.Fatal(err)
return
} // 如果为string传入,则只删除对应的表,如果传入的为Struct,则删除表的同时还会删除对应的索引。
err = engine.DropTables(User1{})
if err!=nil {
log.Fatal(err)
return
}
}
参考:http://gobook.io/read/github.com/go-xorm/manual-zh-CN/
xorm表结构操作实例的更多相关文章
- SQL 表结构操作
数据库知识总结(表结构操作) 1.创建表Scores 1 create table Scores --表名 2 (Id int identity(1,1) primary key,--设置主键,并且行 ...
- SQL server学习(二)表结构操作、SQL函数、高级查询
数据库查询的基本格式为: select ----输出(显示)你要查询出来的值 from -----查询的依据 where -----筛选条件(对依据(数据库中存在的表)) group by ----- ...
- mysql数据表的基本操作:表结构操作,字段操作
本节介绍: 表结构操作 创建数据表. 查看数据表和查看字段. 修改数据表结构 删除数据表 字段操作 新增字段. 修改字段数据类型.位置或属性. 重命名字段 删除字段 首发时间:2018-02-18 ...
- mysql导出word的表结构操作
mysql导出word的表结构操作 1.首先准备好mysql的相关插件mysql-connector-odbc和DBExportDoc 百度网盘地址: 链接:https://pan.baidu.com ...
- MySQL基础~~表结构操作
登录数据库服务器 mysql -h127.0.0.1 -uroot -p123456 创建数据库 create database test; 显示所有数据库 show databases; 指定要操作 ...
- Oracle重建表空间操作实例
由于环境维护或者性能测试需要,经常需要对表空间进行重建操作.重建表空间操作主要分3中情况介绍,分别是业务表空间.临时表空间和回滚段表空间的重建. 重建业务表空间 由于业务规划要求,重建后的业务表空间名 ...
- ORACLE表空间操作实例
本文主要介绍oracle表空间常见的操作实例,包括创建.查询.增加.删除.修改.表空间和数据文件常用的数据字典和动态性能视图包括v$dbfile.v$datafile.v$tempfile.dba_s ...
- SQL Server 表结构操作
一.创建表 --直接定义主外键 create table wallet( ID ) primary key, ,) not null, Name ) default '余额', Member_ID ) ...
- Hibernate之多对多表,操作实例
多表操作之多对多关系简介 思路就是: 在数据库底层通过添加中间表来指定关联关系. 在双方的实体中添加一个保存对方的集合 在双方的配置文件中使用set标签和many-to-many标签来进行关联关系的配 ...
随机推荐
- 表观 | Enhancer | ChIP-seq | 转录因子 | 数据库专题
需要长期更新! 参考:生信修炼手册 enhancer的基本概念: 长度几十到几千bp,作用是提高靶基因活性,属于顺式作用原件,DNA作用到DNA,转录因子就是反式,是结合到DNA的蛋白. 1981年, ...
- 5+app uni-app flutter
5+app uni-app flutter三者区别是什么? - 知乎 https://www.zhihu.com/question/295107584/answer/525442299 崔红保 DCl ...
- SpringBoot整合Hibernate
编写配置文件 <!--配置读取properties文件--> <context:property-placeholder location="classpath:jdbc. ...
- iptables 配置场景3
iptables -I INPUT -i lo -j ACCEPT #允许本地回环地址访问: iptables -I INPUT -m state --state ESTABLISHED,REL ...
- shell编程系列7--shell中常用的工具find、locate、which、whereis
shell编程系列7--shell中常用的工具find.locate.which.whereis .文件查找之find命令 语法格式:find [路径] [选项] [操作] 选项 -name 根据文件 ...
- Ajax serialize()提交form表单不能上传file类型
前台form表单的提交方式有很多种,例如: 1. form表单submit直接提交的方法 2. Ajax提交的方法 3. jquery提交的方法 4. 原生js提交的方法 每一种方法都有它的优势和不足 ...
- 【转载】 我的Machine Learning学习之路
原文地址: https://www.cnblogs.com/steven-yang/p/5857964.html ------------------------------------------- ...
- python中修改列表元素的方法
一.在for循环中直接更改列表中元素的值不会起作用: 如: l = list(range(10)[::2]) print (l) for n in l: n = 0 print (l) 运行结果: [ ...
- ABAP语法篇1 DATA新用法
@DATA 按取数指定的字段定义内表结 定义工作区: SELECT SINGLE * FROM lfbk INTO @DATA(is_lfbk) ...
- FreeMarker的应用场景
FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具. 它不是面向最终用户的,而是一个Java类库,是一 ...