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

notbaron · · 2250 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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

beedb是一个Go进行ORM操作的库,它采用了Go style方式对数据库进行操作,实现了struct到数据表记录的映射。是一个十分轻量级的Go ORM框架,本意降低复杂的ORM学习曲线,尽可能在ORM的运行效率和功能之间寻求一个平衡.

安装

支持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"

)

初始化

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")

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

type Userinfo struct {

   Uid     int `PK` //如果表的主键不是id,那么需要加上pk注释,显式的说这个字段是主键

   Username    string

   Departname  string

   Created     time.Time

}

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

插入数据

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

var saveone Userinfo

saveone.Username = "Test AddUser"

saveone.Departname = "Test AddDepartname"saveone.Created = time.Now()

orm.Save(&saveone)

 

 

 

 


有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:notbaron

查看原文:26.蛤蟆笔记go语言——beedb库使用

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2250 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传