1
0
mirror of https://github.com/astaxie/beego.git synced 2024-11-22 09:40:56 +00:00
Beego/orm
2013-08-07 23:39:18 +08:00
..
docs/zh fix docs link 2013-08-07 23:39:18 +08:00
command.go init orm project, beta, unstable 2013-07-30 20:32:38 +08:00
db_alias.go some fix / add test 2013-08-07 19:11:44 +08:00
db_mysql.go init orm project, beta, unstable 2013-07-30 20:32:38 +08:00
db_oracle.go init orm project, beta, unstable 2013-07-30 20:32:38 +08:00
db_postgres.go init orm project, beta, unstable 2013-07-30 20:32:38 +08:00
db_sqlite.go init orm project, beta, unstable 2013-07-30 20:32:38 +08:00
db.go some fix / add test 2013-08-07 19:11:44 +08:00
models_boot.go some fix / add test 2013-08-07 19:11:44 +08:00
models_fields.go some fix 2013-07-31 22:11:22 +08:00
models_info_f.go some fix / add test 2013-08-07 19:11:44 +08:00
models_info_m.go some fix / add test 2013-08-07 19:11:44 +08:00
models_manager.go some change 2013-08-01 09:23:32 +08:00
models_test.go some fix / add test 2013-08-07 19:11:44 +08:00
models_utils.go init orm project, beta, unstable 2013-07-30 20:32:38 +08:00
models.go some fix / add test 2013-08-07 19:11:44 +08:00
orm_conds.go some fix / add test 2013-08-07 19:11:44 +08:00
orm_object.go some fix / add test 2013-08-07 19:11:44 +08:00
orm_queryset.go some fix / add test 2013-08-07 19:11:44 +08:00
orm_raw.go some fix / add test 2013-08-07 19:11:44 +08:00
orm_test.go some fix / add test 2013-08-07 19:11:44 +08:00
orm.go some fix / add test 2013-08-07 19:11:44 +08:00
README.md update docs 2013-08-07 23:28:14 +08:00
types.go some fix / add test 2013-08-07 19:11:44 +08:00
utils.go some fix / add test 2013-08-07 19:11:44 +08:00

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

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