数据库sql.DB对象如何作为全局对象引用,大家都是怎么写的

Imstrong · 2018-01-04 13:12:15 · 2758 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2018-01-04 13:12:15 的主题,其中的信息可能已经有所发展或是发生改变。

sql.Open()方法为打开连接池,获得返回值为一个数据库的抽象,不需要频繁创建和销毁 目前想到是写在一个go文件中然后大写首字母以导出,可以供其他包访问,但觉得不是很合理 如何将这个对象作为全局对象,使其可以在其他包、文件中引用合理一些呢?


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

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

2758 次点击  
加入收藏 微博
9 回复  |  直到 2018-01-18 20:50:21
yesuu
yesuu · #1 · 7年之前

这样组织吗?

meapp/sql.init 函数,初始化 mepkg/sql.DB meapp/sql.DB 默认 Conn 对象

Imstrong
Imstrong · #2 · 7年之前
yesuuyesuu #1 回复

这样组织吗? `meapp/sql.init` 函数,初始化 `mepkg/sql.DB` `meapp/sql.DB` 默认 Conn 对象

看不懂你写的

mojiajuzi
mojiajuzi · #3 · 7年之前

可以利用上下文context 来进行处理, 可以简单参考一下数据共享这篇文章

specita
specita · #4 · 7年之前

据我经验,全局变量更易用,也可以用一个context,但是代码反而变得复杂起来

Imstrong
Imstrong · #5 · 7年之前
mojiajuzimojiajuzi #3 回复

可以利用上下文`context` 来进行处理, 可以简单参考一下[数据共享](https://mojiajuzi1.gitbooks.io/learn-go/content/patterns/share-data.html)这篇文章

谢谢,我看一下

JJJJJJJerk
JJJJJJJerk · #6 · 7年之前

main.go 文件中import _"your-model-package"` 在your-model-package 里面init函数中 初始化gorm实例 赋值给 modelPackage 的public 变量DB

Imstrong
Imstrong · #7 · 7年之前
JJJJJJJerkJJJJJJJerk #6 回复

`main.go 文件中 `import _"your-model-package"` 在your-model-package 里面init函数中 初始化gorm实例 赋值给 modelPackage 的public 变量DB

用gorm?不用框架现在就是这么做的

JJJJJJJerk
JJJJJJJerk · #8 · 7年之前
ImstrongImstrong #7 回复

#6楼 @JJJJJJJerk 用gorm?不用框架现在就是这么做的

不管是什么orm,确保数据库只初始化一次. 可以把数据库初始化写到main函数或者 init函数中, 数据库初始化的实例 public 就可以了.

xialeistudio
xialeistudio · #9 · 7年之前

项目结构

|---- app db/memcached/redis等等业务无关组件
|---- main.go 主程序

一个实例,db.go

var (
    DB *sql.DB
)

func init() {
    var err error
    DB,err = sql.Open("mysql","xxxx")
    if err != nil {
        log.Fatal(err)
    }
    if err:=DB.Ping();err!=nil {
       log.Fatal(err)
    }
    log.Println("database initialized")
}

不要Close掉了,全局就一个实例,建议设置连接池

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