我尝试在beego中提交表单数据并将其存储到数据库中。并提出一些问题:
我的控制器操作:
func (c *ServicesController) Edit() {
var err error
var id, _ = c.GetUint64(":id")
var serviceModel = models.Service{}
var service models.Service
service, err = serviceModel.FindById(id)
c.Data["Service"] = service
if err == orm.ErrNoRows || err == orm.ErrMissPK {
c.Abort("404")
}
if c.Ctx.Input.IsPost() {
err = nil
if err := c.ParseForm(&service); err != nil {
c.Abort("500")
}
serviceModel.CreateOrUpdate(service)
}
c.TplName = "services/edit.html"
}
型号:
type Service struct {
Id uint64 `form:"-"`
Name string `orm:"size(100)" valid:"Required; MaxSize(100)" form:"name"`
}
func init() {
orm.RegisterModel(new(Service))
}
func (s *Service) FindById(id uint64) (Service, error) {
o := orm.NewOrm()
service := Service{Id: id}
err := o.Read(&service)
return service, err
}
func (s *Service) CreateOrUpdate(service Service) {
o := orm.NewOrm()
o.InsertOrUpdate(&service)
}
但是当我尝试提交表单(使用InsertOrUpdate
)时,无论如何它都会创建新对象,因为我在表单中没有id字段(因为我从路由中的id param中检索对象)。我应该通过id传递形式还是如何破解它?
答案 0 :(得分:2)
解析表单后只需添加ID:
if err := c.ParseForm(&service); err != nil {
c.Abort("500")
}
service.Id = id
透过beego的来源,我认为你可以这样做:
if c.Ctx.Input.IsPost() {
c.Input().Add("id", id)
err = nil
if err := c.ParseForm(&service); err != nil {
c.Abort("500")
}
serviceModel.CreateOrUpdate(service)
}
但如果没有,我会稍微重构你的代码:
func (c *ServicesController) Edit() {
var id, _ = c.GetUint64(":id")
var service models.Service{}
var serviceModel = models.Service{}
var err error
if c.Ctx.Input.IsPost() {
if err = c.ParseForm(&service); err != nil {
c.Abort("500")
}
service.Id = id
serviceModel.CreateOrUpdate(service)
} else {
service, err = serviceModel.FindById(id)
if err == orm.ErrNoRows || err == orm.ErrMissPK {
c.Abort("404")
}
c.Data["Service"] = service
c.TplName = "services/edit.html"
}