从 GORM Raw() Query 中检索数据

我试图通过基于项目的学习来学习Golang。我给自己提出的问题是模拟客户将产品添加到购物车。目前,我有这样的模型。Cart.go


type Cart struct {

     ID         string    

     Customer   Customer  

     CustomerID string    

     Product    Product   

     ProductID  string    

     CreatedAt  time.Time 

     UpdatedAt  time.Time

}

在 Cart 模型上,我有一个函数定义为


func (c *Cart) GetAllItemsInCart(db *gorm.DB, customer_id string) (*gorm.DB, error) {

    items := db.Raw("SELECT id, product_id FROM carts WHERE customer_id = ?", customer_id).Scan(&c)


    return items, nil

}

此函数在控制器中调用


func (server *Server) GetAllCartItems(w http.ResponseWriter, r *http.Request) {

    vars := mux.Vars(r)


    id := vars["id"]


    cart := models.Cart{}


    items, err := cart.GetAllItemsInCart(server.DB, id)


    if err != nil {

        responses.ERROR(w, http.StatusInternalServerError, err)

        return

    }


    responses.JSON(w, http.StatusOK, items)

}

据我所知,目前它将扫描结构的值,或者在这种情况下将找到的数据加载到指定的结构中。但是,我看到的回应是回来的Scan()


 {

    "Value": null,

    "Error": null,

    "RowsAffected": 2

 }

这给了我50%的希望,因为“RowsAffected”:2是正确的。但是,有效负载响应显然不是我正在寻找的。任何指导将不胜感激,谢谢。


胡说叔叔
浏览 212回答 2
2回答

白猪掌柜的

Scan将值放入指向已为其指定的变量的指针中 (),并返回数据库事务对象。您正在调用该事务对象 ,但事实并非如此。项目(即购物车中的内容)位于 中,而不是 返回的内容中。via &citemsc *CartScan您的方法通过填充它进行修改,它不必返回任何内容,除非您要返回可能返回的错误。cScan而不是这个...    items, err := cart.GetAllItemsInCart(server.DB, id)    // ...     responses.JSON(w, http.StatusOK, items)你应该这样做:    err := cart.GetAllItemsInCart(server.DB, id)    // ...    responses.JSON(w, http.StatusOK, cart)

慕尼黑5688855

您需要修复以下几点:您将需要使用而不是因为已经是一个指针。Scan(c)Scan(&c)c您应该始终检查错误。在您的方法中,您不会通过或检查错误。从技术上讲,您确实传递了它(在对象内部),但您不会在任何地方检查它。GetAllItemsInCartitems无需将指针向上传递。*gorm.DB如果你想以你已经开始的方式保留代码的结构,它可能看起来像这样:func (c *Cart) GetAllItemsInCart(db *gorm.DB, customer_id string) error {    return db.Raw("SELECT id, product_id FROM carts WHERE customer_id = ?", customer_id).Scan(c).Error}// controllerfunc (server *Server) GetAllCartItems(w http.ResponseWriter, r *http.Request) {    vars := mux.Vars(r)    id := vars["id"]    cart := models.Cart{}    err := cart.GetAllItemsInCart(server.DB, id)    if err != nil {        responses.ERROR(w, http.StatusInternalServerError, err)        return    }    responses.JSON(w, http.StatusOK, cart)}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go