golang(3):beego CRUD demo (1)

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/46699343 转载请一定注明出处!

1,beego 自带crud生成工具

工具执行非常简单:

bee generate scaffold post -fields="title:string,body:text"

设置模块post,里面的fileds有两个 title 和body。

bee generate scaffold post -fields="title:string,body:text"
2015/06/30 19:00:54 [INFO] Using 'post' as scaffold name
2015/06/30 19:00:54 [INFO] Do you want me to create a post model? [yes|no]]  yes
2015/06/30 19:00:56 [INFO] Using 'Post' as model name
2015/06/30 19:00:56 [INFO] Using 'models' as package name
2015/06/30 19:00:56 [INFO] model file generated: /Users/freewebsys/Workspace_go/demo1/src/models/post.go
2015/06/30 19:00:56 [INFO] Do you want me to create a post controller? [yes|no]]  yes
2015/06/30 19:00:58 [INFO] Using 'Post' as controller name
2015/06/30 19:00:58 [INFO] Using 'controllers' as package name
2015/06/30 19:00:58 [INFO] controller file generated: /Users/freewebsys/Workspace_go/demo1/src/controllers/post.go
2015/06/30 19:00:58 [INFO] Do you want me to create views for this post resource? [yes|no]]  yes
2015/06/30 19:01:01 [INFO] Created: /Users/freewebsys/Workspace_go/demo1/src/views/post/index.tpl
2015/06/30 19:01:01 [INFO] Created: /Users/freewebsys/Workspace_go/demo1/src/views/post/show.tpl
2015/06/30 19:01:01 [INFO] Created: /Users/freewebsys/Workspace_go/demo1/src/views/post/create.tpl
2015/06/30 19:01:01 [INFO] Created: /Users/freewebsys/Workspace_go/demo1/src/views/post/edit.tpl
2015/06/30 19:01:01 [INFO] Do you want me to create a post migration and schema for this resource? [yes|no]]  yes
2015/06/30 19:01:07 [INFO] Migration file generated: /Users/freewebsys/Workspace_go/demo1/src/database/migrations/20150630_190107_post.go
2015/06/30 19:01:07 [INFO] Do you want to go ahead and migrate the database? [yes|no]]  no
2015/06/30 19:01:09 [INFO] All done! Don't forget to add  beego.Router("/post" ,&controllers.PostController{}) to routers/route.go
2015/06/30 19:01:09 [SUCC] generate successfully created!

生成了一堆代码,但是controller的代码是空方法,生成的页面代也是只有一行。

models里面的代码很全:

package models

import (
    "errors"
    "fmt"
    "reflect"
    "strings"

    "github.com/astaxie/beego/orm"
)

type Post struct {
    Id    int64  `orm:"auto"`
    Title string `orm:"size(128)"`
    Body  string `orm:"type(longtext)"`
}

func init() {
    orm.RegisterModel(new(Post))
}

// AddPost insert a new Post into database and returns
// last inserted Id on success.
func AddPost(m *Post) (id int64, err error) {
    o := orm.NewOrm()
    id, err = o.Insert(m)
    return
}

// GetPostById retrieves Post by Id. Returns error if
// Id doesn't exist
func GetPostById(id int) (v *Post, err error) {
    o := orm.NewOrm()
    v = &Post{Id: id}
    if err = o.Read(v); err == nil {
        return v, nil
    }
    return nil, err
}

// GetAllPost retrieves all Post matches certain condition. Returns empty list if
// no records exist
func GetAllPost(query map[string]string, fields []string, sortby []string, order []string,
    offset int64, limit int64) (ml []interface{}, err error) {
    o := orm.NewOrm()
    qs := o.QueryTable(new(Post))
    // query k=v
    for k, v := range query {
        // rewrite dot-notation to Object__Attribute
        k = strings.Replace(k, ".", "__", -1)
        qs = qs.Filter(k, v)
    }
    // order by:
    var sortFields []string
    if len(sortby) != 0 {
        if len(sortby) == len(order) {
            // 1) for each sort field, there is an associated order
            for i, v := range sortby {
                orderby := ""
                if order[i] == "desc" {
                    orderby = "-" + v
                } else if order[i] == "asc" {
                    orderby = v
                } else {
                    return nil, errors.New("Error: Invalid order. Must be either [asc|desc]")
                }
                sortFields = append(sortFields, orderby)
            }
            qs = qs.OrderBy(sortFields...)
        } else if len(sortby) != len(order) && len(order) == 1 {
            // 2) there is exactly one order, all the sorted fields will be sorted by this order
            for _, v := range sortby {
                orderby := ""
                if order[0] == "desc" {
                    orderby = "-" + v
                } else if order[0] == "asc" {
                    orderby = v
                } else {
                    return nil, errors.New("Error: Invalid order. Must be either [asc|desc]")
                }
                sortFields = append(sortFields, orderby)
            }
        } else if len(sortby) != len(order) && len(order) != 1 {
            return nil, errors.New("Error: 'sortby', 'order' sizes mismatch or 'order' size is not 1")
        }
    } else {
        if len(order) != 0 {
            return nil, errors.New("Error: unused 'order' fields")
        }
    }

    var l []Post
    qs = qs.OrderBy(sortFields...)
    if _, err := qs.Limit(limit, offset).All(&l, fields...); err == nil {
        if len(fields) == 0 {
            for _, v := range l {
                ml = append(ml, v)
            }
        } else {
            // trim unused fields
            for _, v := range l {
                m := make(map[string]interface{})
                val := reflect.ValueOf(v)
                for _, fname := range fields {
                    m[fname] = val.FieldByName(fname).Interface()
                }
                ml = append(ml, m)
            }
        }
        return ml, nil
    }
    return nil, err
}

// UpdatePost updates Post by Id and returns error if
// the record to be updated doesn't exist
func UpdatePostById(m *Post) (err error) {
    o := orm.NewOrm()
    v := Post{Id: m.Id}
    // ascertain id exists in the database
    if err = o.Read(&v); err == nil {
        var num int64
        if num, err = o.Update(m); err == nil {
            fmt.Println("Number of records updated in database:", num)
        }
    }
    return
}

// DeletePost deletes Post by Id and returns error if
// the record to be deleted doesn't exist
func DeletePost(id int) (err error) {
    o := orm.NewOrm()
    v := Post{Id: id}
    // ascertain id exists in the database
    if err = o.Read(&v); err == nil {
        var num int64
        if num, err = o.Delete(&Post{Id: id}); err == nil {
            fmt.Println("Number of records deleted in database:", num)
        }
    }
    return
}

3,运行项目

要运行项目需要再src目录下面增加一个main.go

package main

import (
    _ "routers"
    "github.com/astaxie/beego"
)

func main() {
    beego.Run()
}

同时在,src/routers,下面增加router.go

package routers

import (
    "controllers"
    "github.com/astaxie/beego"
)

func init() {

    beego.Router("/post/list",&controllers.PostController{},"get:List")
    beego.Router("/post/edit",&controllers.PostController{},"get:Edit")
    beego.Router("/post/save",&controllers.PostController{},"post:Save")
    beego.Router("/post/delete",&controllers.PostController{},"delete:Delete")
}

由于controller没有自动生成,需要自己修改:

package controllers

import (
    "github.com/astaxie/beego"
)

// operations for Post
type PostController struct {
    beego.Controller
}

func (c *PostController) List() {
    c.TplNames = "post/list.tpl"
}

func (c *PostController) Edit() {
    c.TplNames = "post/edit.tpl"
}

func (c *PostController) Save() {
    c.Ctx.WriteString("hello")
    //c.TplNames = "post/index.tpl"
}

func (c *PostController) Delete() {
    c.Ctx.WriteString("hello")
    //c.TplNames = "post/index.tpl"
}

4,总结

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/46699343 转载请一定注明出处!

对beego的代码生成工具有了一个简单的了解,其中mvc中,module代码生成的比较完善,其他的只生成一个文件而已。

时间: 2024-10-26 05:51:18

golang(3):beego CRUD demo (1)的相关文章

Senparc.Weixin.MP SDK 微信公众平台开发教程(七):解决用户上下文(Session)问题

原文:Senparc.Weixin.MP SDK 微信公众平台开发教程(七):解决用户上下文(Session)问题     从这篇文章中我们已经了解了微信公众平台消息传递的方式,这种方式有一个先天的缺陷:不同用户的请求都来自同一个微信服务器,这使得常规的Session无法使用(始终面对同一个请求对象,况且还有对方服务器Cookie是否能保存的问题).     这就要求我们自己建立一套独立的对话上下文请求机制.     上一篇<Senparc.Weixin.MP SDK 微信公众平台开发教程(六)

我的WCF之旅(7):面向服务架构(SOA)和面向对象编程(OOP)的结合——如何实现Service Contract的继承

当今的IT领域,SOA已经成为了一个非常时髦的词,对SOA风靡的程度已经让很多人对SOA,对面向服务产生误解.其中很大一部分人甚至认为面向服务将是面向对象的终结,现在的面向对象将会被面向服务完全代替.在开始本Blog之前,我先来谈谈我对SOA和OO的区别,首先申明,这只是一家之言,欢迎大家批评指正,并且关于SO的谈论不是本Blog的主题,只是主题的引子,在这里只是简单讨论而已 . OO和SO之间具有共同的部分,在运用的领域上存在交集,只有在基于他们交集层面上谈论谁是谁非才有意义,下面是我对SO和

Windows Phone开发(10):常用控件(上)

原文:Windows Phone开发(10):常用控件(上) Windows Phone的控件有几个来源,和传统的桌面应用程序开发或Web开发一样,有默认提供的控件和第三方开者发布的控件.一般而言,如果不是过于复杂的界面布局,使用默认控件就足矣.相比之下,Android SDK中尽管提供了许多可视化控件,但你会发现,实际开发用到的并不多,而且很多控件完全只是摆设,既没有公开相应的操作方法也没有更多可用于开发者自行处理的监听器(这里我习惯翻译为监听器,在安卓里面没有像C#那样使用事件,而是new一

Blend4精选案例图解教程(一):丰富的形状(Shape)资源

原文:Blend4精选案例图解教程(一):丰富的形状(Shape)资源       Blend4资源面板中内置了丰富的形状素材,为我们在构建程序时提供极大的方便.系统默认内置18种常用形状,通过其属性设置可以自定义出更多衍生形状,或者通过Direct Selection工具手动绘制,我们可以获得更自由的形状编辑.当然我们还可以登陆 Expression Gallery 下载别人分享的素材(似乎并不多),来扩充形状资源库.       因为形状的用法比较一致,重点是形状的不同属性设置,在此仅举一例

CoreOS实践指南(六):分布式数据存储Etcd(下)

注:本文首发于CSDN,转载请标明出处. [编者按]在"漫步云端:CoreOS实践指南"系列第五篇: 分布式数据存储Etcd(上)中,ThoughtWorks的软件工程师林帆从系统运维工作者的角度介绍了Etcd的操作和API的使用.本文为分布式数据存储Etcd的下篇.Etcd是CoreOS生态系统中处于连接各个节点通信和支撑集群服务协同运作的核心地位的模块,这篇文章将主要介绍Etcd的RESTful API.如果说Etcd数据存储服务是CoreOS分布式架构的基石,那么Etcd的RES

ASP编程入门进阶(十九):ASP技巧累加(二)

编程|技巧|技巧 严格控制Session 可以将不需要Session的内容(比如帮助画面,访问者区域,等等)移动到关闭Session的独立ASP应用程序中.在基础页面上,可以给ASP一个指示,让它不需要使用Session.将下面的代码直接加入到ASP页面的头部: <%@EnableSessionState=False%> 在Web服务器上缓存经常使用的数据 典型的情况是:ASP页面从后台存储中取回数据,然后以超文本标记语言(HTML)的形式形成结果.不管数据库的速度如何,从内存中取回数据要比从

WPF and Silverlight学习笔记(二十四):数据源提供器(DataProvider)

在WPF中系统提供了两个数据源提供器(DataProvider):对象数据源提供器 (ObjectDataProvider)和XML数据源提供器(XmlDataProvider).其作用类似 于ASP.Net数据源(DataSource)中的对象数据源(ObjectDataSource)和Xml数 据源(XmlDataSource).其继承结构如下: ObjectDataProvider用于处理由方法返回值所产生的数据源,其应用 非常广泛,通常多层应用程序通常在界面上使用ObjectDataPr

深入理解JavaScript系列(47):对象创建模式(上篇)_基础知识

介绍 本篇主要是介绍创建对象方面的模式,利用各种技巧可以极大地避免了错误或者可以编写出非常精简的代码. 模式1:命名空间(namespace) 命名空间可以减少全局命名所需的数量,避免命名冲突或过度.一般我们在进行对象层级定义的时候,经常是这样的: 复制代码 代码如下: var app = app || {}; app.moduleA = app.moduleA || {}; app.moduleA.subModule = app.moduleA.subModule || {}; app.mod

常见的五类排序算法图解和实现(交换类:冒泡排序,递归的快速排序)

冒泡排序算法: 总的来说就是两两交换,反复直到有序,第一个记录和第二个记录,若逆序则交换,然后比较第二个和第三个记录,以此类推,直到第 n 个记录和第 n-1个记录比较完毕为止,第一趟排序,结果关键字最大的记录被安排在最后一个位置.对前 n-1个记录继续冒泡排序,使得关键字次大的记录安排在第 n-1个位置.如此重复,直到没有需要交换的记录为止(仅仅是第一个和第二个交换过为止).整个一趟趟的选出最值的过程,仿佛是那水里的气泡,咕嘟咕嘟的往上翻的过程. 递增冒泡排序过程图解: 一般先比较第一个元素和