beedb是我开发的一个Go进行ORM操作的库,它采用了Go style方式对数据库进行操作,实现了struct到数据表记录的映射。beedb是一个十分轻量级的Go ORM框架,开发这个库的本意降低复杂的ORM学习曲线,尽可能在ORM的运行效率和功能之间寻求一个平衡,beedb是目前开源的Go ORM框架中实现比较完整的一个库,而且运行效率相当不错,功能也基本能满足需求。但是目前还不支持关系关联,这个是接下来版本升级的重点。

beedb是支持database/sql标准接口的ORM库,所以理论上来说,只要数据库驱动支持database/sql接口就可以无缝的接入beedb。目前我测试过的驱动包括下面几个:

Mysql:github.com/ziutek/mymysql/godrv[*]

Mysql:code.google.com/p/go-mysql-driver[*]

PostgreSQL:github.com/bmizerany/pq[*]

SQLite:github.com/mattn/go-sqlite3[*]

MS ADODB: github.com/mattn/go-adodb[*]

ODBC: bitbucket.org/miquella/mgodbc[*]

安装

beedb支持go get方式安装,是完全按照Go Style的方式来实现的。

go get github.com/astaxie/beedb

如何初始化

首先你需要import相应的数据库驱动包、database/sql标准接口包以及beedb包,如下所示:

import ("database/sql""github.com/astaxie/beedb"_ "github.com/ziutek/mymysql/godrv"
)

导入必须的package之后,我们需要打开到数据库的链接,然后创建一个beedb对象(以MySQL为例),如下所示

db, err := sql.Open("mymysql", "test/xiemengjun/123456")
if err != nil {panic(err)
}
orm := beedb.New(db)

beedb的New函数实际上应该有两个参数,第一个参数标准接口的db,第二个参数是使用的数据库引擎,如果你使用的数据库引擎是MySQL/Sqlite,那么第二个参数都可以省略。

如果你使用的数据库是SQLServer,那么初始化需要:

orm = beedb.New(db, "mssql")

如果你使用了PostgreSQL,那么初始化需要:

orm = beedb.New(db, "pg")

目前beedb支持打印调试,你可以通过如下的代码实现调试

beedb.OnDebug=true

接下来我们的例子采用前面的数据库表Userinfo,现在我们建立相应的struct

type Userinfo struct {Uid     int `PK` //如果表的主键不是id,那么需要加上pk注释,显式的说这个字段是主键Username    stringDepartname  stringCreated     time.Time
}

注意一点,beedb针对驼峰命名会自动帮你转化成下划线字段,例如你定义了Struct名字为UserInfo,那么转化成底层实现的时候是user_info,字段命名也遵循该规则。

插入数据

下面的代码演示了如何插入一条记录,可以看到我们操作的是struct对象,而不是原生的sql语句,最后通过调用Save接口将数据保存到数据库。

var saveone Userinfo
saveone.Username = "Test Add User"
saveone.Departname = "Test Add Departname"
saveone.Created = time.Now()
orm.Save(&saveone)

我们看到插入之后saveone.Uid就是插入成功之后的自增ID。Save接口会自动帮你存进去。

beedb接口提供了另外一种插入的方式,map数据插入。

add := make(map[string]interface{})
add["username"] = "astaxie"
add["departname"] = "cloud develop"
add["created"] = "2012-12-02"
orm.SetTable("userinfo").Insert(add)

插入多条数据

addslice := make([]map[string]interface{}, 0)
add:=make(map[string]interface{})
add2:=make(map[string]interface{})
add["username"] = "astaxie"
add["departname"] = "cloud develop"
add["created"] = "2012-12-02"
add2["username"] = "astaxie2"
add2["departname"] = "cloud develop2"
add2["created"] = "2012-12-02"
addslice =append(addslice, add, add2)
orm.SetTable("userinfo").InsertBatch(addslice)

上面的操作方式有点类似链式查询,熟悉jquery的同学应该会觉得很亲切,每次调用的method都会返回原orm对象,以便可以继续调用该对象上的其他method。

上面我们调用的SetTable函数是显式的告诉ORM,我要执行的这个map对应的数据库表是userinfo

更新数据

继续上面的例子来演示更新操作,现在saveone的主键已经有值了,此时调用save接口,beedb内部会自动调用update以进行数据的更新而非插入操作。

saveone.Username = "Update Username"
saveone.Departname = "Update Departname"
saveone.Created = time.Now()
orm.Save(&saveone)  //现在saveone有了主键值,就执行更新操作

更新数据也支持直接使用map操作

t := make(map[string]interface{})
t["username"] = "astaxie"
orm.SetTable("userinfo").SetPK("uid").Where(2).Update(t)

这里我们调用了几个beedb的函数

SetPK:显式的告诉ORM,数据库表userinfo的主键是uid

Where:用来设置条件,支持多个参数,第一个参数如果为整数,相当于调用了Where("主键=?",值)。 Updata函数接收map类型的数据,执行更新数据。

查询数据

beedb的查询接口比较灵活,具体使用请看下面的例子

例子1,根据主键获取数据:

var user Userinfo
//Where接受两个参数,支持整形参数
orm.Where("uid=?", 27).Find(&user)

例子2:

var user2 Userinfo
orm.Where(3).Find(&user2) // 这是上面版本的缩写版,可以省略主键

例子3,不是主键类型的的条件:

var user3 Userinfo
//Where接受两个参数,支持字符型的参数
orm.Where("name  = ?", "john").Find(&user3)

例子4,更加复杂的条件:

var user4 Userinfo
//Where支持三个参数
orm.Where("name = ? and age < ?", "john", 88).Find(&user4)

可以通过如下接口获取多条数据,请看示例

例子1,根据条件id>3,获取20位置开始的10条数据的数据

var allusers []Userinfo
err := orm.Where("id > ?", "3").Limit(10,20).FindAll(&allusers)

例子2,省略limit第二个参数,默认从0开始,获取10条数据

var tenusers []Userinfo
err := orm.Where("id > ?", "3").Limit(10).FindAll(&tenusers)

例子3,获取全部数据

var everyone []Userinfo
err := orm.OrderBy("uid desc,username asc").FindAll(&everyone)

上面这些里面里面我们看到一个函数Limit,他是用来控制查询结构条数的。

Limit:支持两个参数,第一个参数表示查询的条数,第二个参数表示读取数据的起始位置,默认为0。

OrderBy:这个函数用来进行查询排序,参数是需要排序的条件。

上面这些例子都是将获取的的数据直接映射成struct对象,如果我们只是想获取一些数据到map,以下方式可以实现:

a, _ := orm.SetTable("userinfo").SetPK("uid").Where(2).Select("uid,username").FindMap()

上面和这个例子里面又出现了一个新的接口函数Select,这个函数用来指定需要查询多少个字段。默认为全部字段*

FindMap()函数返回的是[]map[string][]byte类型,所以你需要自己作类型转换。

删除数据

beedb提供了丰富的删除数据接口,请看下面的例子

例子1,删除单条数据

//saveone就是上面示例中的那个saveone
orm.Delete(&saveone)

例子2,删除多条数据

//alluser就是上面定义的获取多条数据的slice
orm.DeleteAll(&alluser)

例子3,根据sql删除数据

orm.SetTable("userinfo").Where("uid>?", 3).DeleteRow()

关联查询

目前beedb还不支持struct的关联关系,但是有些应用却需要用到连接查询,所以现在beedb提供了一个简陋的实现方案:

a, _ := orm.SetTable("userinfo").Join("LEFT", "userdeatail", "userinfo.uid=userdeatail.uid").Where("userinfo.uid=?", 1).Select("userinfo.uid,userinfo.username,userdeatail.profile").FindMap()

上面代码中我们看到了一个新的接口Join函数,这个函数带有三个参数

  • 第一个参数可以是:INNER, LEFT, OUTER, CROSS等
  • 第二个参数表示连接的表
  • 第三个参数表示连接的条件

Group By和Having

针对有些应用需要用到group by和having的功能,beedb也提供了一个简陋的实现

a, _ := orm.SetTable("userinfo").GroupBy("username").Having("username='astaxie'").FindMap()

上面的代码中出现了两个新接口函数

GroupBy:用来指定进行groupby的字段

Having:用来指定having执行的时候的条件

进一步的发展

目前beedb已经获得了很多来自国内外用户的反馈,我目前也正在考虑重构,接下来会在几个方面进行改进

  • 实现interface设计,类似databse/sql/driver的设计,设计beedb的接口,然后去实现相应数据库的CRUD操作

  • 实现关联数据库设计,支持一对一,一对多,多对多的实现,示例代码如下:

    type Profile struct{ Nickname string Mobile string }

    type Userinfo struct { Uid int PK Username string Departname string Created time.Time Profile HasOne }

  • 自动建库建表建索引

  • 实现连接池的实现,采用goroutine

go使用beedb库进行ORM开发相关推荐

  1. beedb mysql_26.蛤蟆笔记go语言——beedb库使用

    26.蛤蟆笔记go语言--beedb库使用 beedb是一个Go进行ORM操作的库,它采用了Go style方式对数据库进行操作,实现了struct到数据表记录的映射.是一个十分轻量级的Go ORM框 ...

  2. 视频库:人工智能开发_人工智能工程师_AI人工智能

    人工智能Python语言入手→→机器学习核心技术→→深度学习核心技术→→NLP自然语言处理技术→→CV计算机视觉技术 视频库:人工智能开发_人工智能工程师_AI人工智能 01-人工智能开发入门 掌握P ...

  3. Mixly第三方库开发的两种方法——U8g2库二次开发

    Mixly第三方库开发的两种方法--U8g2库二次开发 前言 方法一:自定义库 1.创建库文件夹 2.开始编程 2.1.定义图形块的基本信息 2.2.定义图形块的外观样式 2.3.定义图形块与C语言的 ...

  4. VS2019+QGIS开发库二次开发环境搭建

    VS2019+QGIS开发库二次开发环境搭建 总共分为以下步骤: 下载qgis和二次开发库 VS2019搭建开发环境 配置VS2019中的Qt插件 配置完Qt版本后对工程属性进行配置 编写测试代码 运 ...

  5. 基于CyberGarage库的dlna开发(android)

    关于dlna的介绍就不多说了,具体可以看这篇博文http://blog.csdn.net/geniuseoe2012/article/details/8230877 或者问百度谷歌 Dlna通讯采用u ...

  6. python做游戏用什么库_Python库之游戏开发及虚拟现实

    Python库之游戏开发及虚拟现实 发布时间:2019-04-06 20:47, 浏览次数:320 , 标签: Python <>1.PyGame:简单的游戏开发功能库 http://ww ...

  7. 基于live555中的liveMedia库的client开发流程 此博文包含图片

    基于live555中的liveMedia库的client开发流程 转载▼ 如今流媒体无处不在,而主流流媒体服务器为Realworks.Windows Media Server.Apple Darwin ...

  8. 【HAL库】STM32CubeMX开发----STM32F103/F207/F407----时钟配置

    STM32CubeMX 下载和安装 详细教程 [HAL库]STM32CubeMX开发----STM32F103/F207/F407----目录 一.STM32F103----时钟配置 外部时钟源 = ...

  9. 【HAL库】STM32CubeMX开发----delay延时实验----NOP空指令

    STM32CubeMX 下载和安装 详细教程 [HAL库]STM32CubeMX开发----STM32F103/F207/F407----目录 前言 HAL库有自带的 ms级 延时函数: HAL_De ...

最新文章

  1. 收藏 | 数据分析师最常用的10个机器学习算法!(附图解)
  2. 网络资源(4) - extJS视频
  3. Linux环境——MySQL安装及配置(8.0版本)
  4. [转载]从零开始学习jQuery (一) 开天辟地入门篇
  5. ELF文件的格式和加载过程
  6. 一摞烙饼最上面一个的另一面为焦的概率
  7. web_xml 控制web行为
  8. SSLH:让 HTTPS 和 SSH 共享同一个端口
  9. Spark.shuffle.file.buffer 参数入门
  10. 阶段3 2.Spring_04.Spring的常用注解_4 由Component衍生的注解
  11. 467.环绕字符串中唯一的子字符串
  12. java代码鸡兔同笼_鸡兔同笼 java代码
  13. 冰点下载器手机版apk_冰点文库下载器安卓手机版
  14. python搭建简易HTTPServer服务
  15. 杯具了~湖北省浠水县国家税务局局长叫作「操高潮」 (豆瓣 我们爱讲冷笑话小组)...
  16. auto-cpufreq安装及配置过程
  17. 大数据-机器学习导论-1
  18. 理解ES6中暂时性死区TDZ
  19. 迭代器Iterator的用法
  20. 分享免端口访问群晖的方法,可以顶级域名

热门文章

  1. 【鸿蒙 HarmonyOS】HarmonyOS 开发环境搭建 ( Node.js 安装 )
  2. 【Android 异步操作】线程池 ( 线程池简介 | 线程池初始化方法 | 线程池种类 | AsyncTask 使用线程池示例 )
  3. 【Android 高性能音频】hello-oboe 示例解析 ( Oboe 源代码依赖 | CMakeList.txt 构建脚本分析 | Oboe 源代码构建脚本分析 )
  4. 【Android RTMP】Android Studio 集成 x264 开源库 ( Ubuntu 交叉编译 | Android Studio 导入函数库 )
  5. HTML和JavaScript代码分离、平稳退化(1)
  6. C# ManualResetEvent
  7. jQuery Mobile Slider Widget 使用js控制
  8. 第二部分:S5PV210_关看门狗_1
  9. Unity-3d Day03
  10. Asp.net 后台添加CSS、JS、Meta标签