我尝试在Go&Beego上创建一个简单的REST服务。

我不明白Beego的逻辑。

所有示例都包含有关如何在我需要获取所有项目的同时仅检索一项的信息。

如果是API。

控制器:

package controllers
import (
    "api/models"
    "github.com/astaxie/beego"
)

type UserController struct {
    beego.Controller
}

func (u *UserController) GetAll() {
    users := models.GetAllUsers()
    u.Data["json"] = users
    u.ServeJSON()
}

型号:
package models

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

var (
    UserList map[int]*User
)

func init() {
    orm.RegisterModel(new(User))

    UserList = make(map[int]*User)

    u := User{1, "Chandler", "Bing", "chandlerbing@gmail.com"}
    UserList[1] = &u
}

type User struct {
    Id int `form:"id"`
    First_name string `form:"first_name"`
    Last_name string `form:"last_name"`
    Email string `form:"email"`
}

func GetAllUsers() map[int]*User {
    return UserList
}

这样可行!但是,如何从数据库中获取数据?

数据库连接正常(MySQL)

最佳答案

您应该使用QueryTable提及here

var users []*User
num, err := o.QueryTable("user").Filter("name", "slene").All(&users)

在您的情况下,您的GetAllUsers应该看起来像这样,但我没有对其进行测试。
func GetAllUsers() map[int]*User {
    usrs, err := orm.QueryTable("users").Values(&UserList)
    if err != nil {
        panic(err)
    }
    return UserList
}

10-06 16:16
查看更多