Name Last Update
..
docs/zh Loading commit data...
README.md Loading commit data...
command.go Loading commit data...
db.go Loading commit data...
db_alias.go Loading commit data...
db_mysql.go Loading commit data...
db_oracle.go Loading commit data...
db_postgres.go Loading commit data...
db_sqlite.go Loading commit data...
models.go Loading commit data...
models_boot.go Loading commit data...
models_fields.go Loading commit data...
models_info_f.go Loading commit data...
models_info_m.go Loading commit data...
models_manager.go Loading commit data...
models_test.go Loading commit data...
models_utils.go Loading commit data...
orm.go Loading commit data...
orm_conds.go Loading commit data...
orm_object.go Loading commit data...
orm_queryset.go Loading commit data...
orm_raw.go Loading commit data...
orm_test.go Loading commit data...
types.go Loading commit data...
utils.go Loading commit data...

beego orm

a powerful orm framework

now, beta, unstable, may be changing some api make your app build failed.

Driver Support:

Features:

...

Install:

go get github.com/astaxie/beego/orm

Quick Start

Simple Usage

package main

import (
    "fmt"
    "github.com/astaxie/beego/orm"
    _ "github.com/go-sql-driver/mysql" // import your used driver
)

// Model Struct
type User struct {
    Id   int    `orm:"auto"`
    Name string `orm:"size(100)"`
    orm.Manager
}

func init() {
    // register model
    orm.RegisterModel(new(User))

    // set default database
    orm.RegisterDataBase("default", "mysql", "root:root@/my_db?charset=utf8", 30)
}

func main() {
    o := orm.NewOrm()

    user := User{Name: "slene"}

    // insert
    id, err := o.Insert(&user)

    // update
    user.Name = "astaxie"
    num, err := o.Update(&user)

    // read one
    u := User{Id: user.Id}
    err = o.Read(&u)

    // delete
    num, err = o.Delete(&u) 
}

Next with relation

type Post struct {
    Id    int    `orm:"auto"`
    Title string `orm:"size(100)"`
    User  *User  `orm:"rel(fk)"`
    orm.Manager
}

var posts []*Post
qs := o.QueryTable("post")
num, err := qs.Filter("User__Name", "slene").All(&posts)

Use Raw sql

If you don't like ORM,use Raw SQL to query / mapping without ORM setting

var maps []Params
num, err := o.Raw("SELECT id FROM user WHERE name = ?", "slene").Values(&maps)
if num > 0 {
    fmt.Println(maps[0]["id"])
}

Transaction

o.Begin()
...
user := User{Name: "slene"}
id, err := o.Insert(&user)
if err != nil {
    o.Commit()
} else {
    o.Rollback()
}

Docs

more details and examples in docs and test

TODO

  • some unrealized api
  • examples
  • docs
  • support sqlite
  • support postgres