连接示例
import (
"gopkg.in/mgo.v2"
"gopkg.in/mgo.v2/bson"
)
// 连接数据库
// func Dial(url string) (*Session, error)
session, err := mgo.Dial("")
session, err := mgo.Dial("127.0.0.1")
session, err := mgo.Dial("localhost:27017")
// 获取 databse 和 collection
// func (s *Session) DB(name string) *Database
db := session.DB("test")
// func (db *Database) C(name string) *Collection
c := db.C("users")
// session 使用完毕后需要手动回收
defer session.Close()
- 建会话session
session,error :=mgo.Dail(url)
- 获取database
db:=session.DB("test")
- 获取collection
c :=db.C("users")
- 关闭session
通常通过在拨号时获得的初始会话中调用session.Copy创建新会话。这些新的会话将共享相同的集群信息和连接池,并且可以容易地交给用于组织逻辑的其他方法和功能。创建的每个会话都必须在其生命周期结束时调用其Close方法,因此根据情况,其资源可能会放回池中或收集。。
api
定义变量
var (
ErrNotFound = errors.New("not found")
ErrCursor = errors.New("invalid cursor")
)
检查错误是不是插入id重复的错误
func IsDup(err error) bool
设置打印的log
func SetLogger(logger log_Logger)
日志输出是debug还是正常模式
func SetDebug(debug bool)