获取数据库信息

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表结构操作实例的更多相关文章

  1. SQL 表结构操作

    数据库知识总结(表结构操作) 1.创建表Scores 1 create table Scores --表名 2 (Id int identity(1,1) primary key,--设置主键,并且行 ...

  2. SQL server学习(二)表结构操作、SQL函数、高级查询

    数据库查询的基本格式为: select ----输出(显示)你要查询出来的值 from -----查询的依据 where -----筛选条件(对依据(数据库中存在的表)) group by ----- ...

  3. mysql数据表的基本操作:表结构操作,字段操作

    本节介绍: 表结构操作 创建数据表. 查看数据表和查看字段. 修改数据表结构 删除数据表 字段操作 新增字段. 修改字段数据类型.位置或属性. 重命名字段 删除字段 首发时间:2018-02-18  ...

  4. mysql导出word的表结构操作

    mysql导出word的表结构操作 1.首先准备好mysql的相关插件mysql-connector-odbc和DBExportDoc 百度网盘地址: 链接:https://pan.baidu.com ...

  5. MySQL基础~~表结构操作

    登录数据库服务器 mysql -h127.0.0.1 -uroot -p123456 创建数据库 create database test; 显示所有数据库 show databases; 指定要操作 ...

  6. Oracle重建表空间操作实例

    由于环境维护或者性能测试需要,经常需要对表空间进行重建操作.重建表空间操作主要分3中情况介绍,分别是业务表空间.临时表空间和回滚段表空间的重建. 重建业务表空间 由于业务规划要求,重建后的业务表空间名 ...

  7. ORACLE表空间操作实例

    本文主要介绍oracle表空间常见的操作实例,包括创建.查询.增加.删除.修改.表空间和数据文件常用的数据字典和动态性能视图包括v$dbfile.v$datafile.v$tempfile.dba_s ...

  8. SQL Server 表结构操作

    一.创建表 --直接定义主外键 create table wallet( ID ) primary key, ,) not null, Name ) default '余额', Member_ID ) ...

  9. Hibernate之多对多表,操作实例

    多表操作之多对多关系简介 思路就是: 在数据库底层通过添加中间表来指定关联关系. 在双方的实体中添加一个保存对方的集合 在双方的配置文件中使用set标签和many-to-many标签来进行关联关系的配 ...

随机推荐

  1. 两个Double类型相减出现精度丢失问题

    两个Double类型相减出现精度丢失问题 720.50-279.5=440.099999999 而不是440.1 解决方法,将数据库中的类型改为decimal类型,小数精确到2位

  2. QEMU支持的网络模式

    网络是现代计算机系统不可或缺的一部分,QEMU也对虚拟机提供丰富的网络支持.qemu-kvm中主要给客户机提供了如下4种不同模式的网络. (1)基于网桥(Bridge)的虚拟网卡 (2)基于NAT(N ...

  3. Nginx + Naxsi 打造建议WAF

    --prefix=/usr/share/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf ...

  4. 【E2E】Tesseract5+VS2017+win10源码编译攻略

    一,记录我目前在win10 X64和VS2017的环境下成功编译Tesseract5.0的方式: 二,记录在VS2017 C++工程中调用Tesseract4.0的方法: 三,记录编译和调用Tesse ...

  5. Nginx之https配置 - 运维笔记 (http->https强转)

    一.Nginx安装(略)安装的时候需要注意加上 --with-http_ssl_module,因为http_ssl_module不属于Nginx的基本模块.Nginx安装方法: # ./configu ...

  6. 解决IE浏览器没有网络的情况

    计算机能够连接到网络,但是IE浏览器却显示没有网络. 解决方案: 设置 >> IE internet选项: 选择“高级”: 选择“重置”: 勾选“删除个人设置”,点击重置: 重新打开IE, ...

  7. mobile crane 1

    void MobileCrane::rotateRope2() { //double r_angle1 = rotateRope + rorate3; //std::cout << &qu ...

  8. 算法习题---5.3字典(Uva10815)

    一:题目 给出一段英文,里面包含一些单词,空格和标点,单词不区分大小写,默认都为小写.按照字典序输出这些单词(这些单词不能有重复,字母全部变成小写) (一)样例输入 Adventures in Dis ...

  9. 【Linux】反向代理

    Nginx server { root /data/wwwroot/; server_name www.test.com; location / { proxy_http_version 1.1; p ...

  10. Spring Cloud 如何实现服务间的调用 4.2.3

      如果存在多个服务时,要怎么通过注册中心来实现服务之间的调用呢?接下来将通过一个用户和订单之间的调用案例,来演示Eureka Server中服务之间的调用. 搭建订单服务工程 在父工程xcservi ...