doujiu8178 2018-08-09 16:53
浏览 39
已采纳

如何在Buffalo中执行原始SQL?

How can I execute raw SQL queries in Buffalo without having to set up my own db connection with sqlx?

To clarify: I have my database connection defined in database.yml, but I don't want to use Pop models at this time.

  • 写回答

1条回答 默认 最新

  • doutui6644 2018-08-09 18:51
    关注

    You can also define your RawQueries with Pop: https://godoc.org/github.com/gobuffalo/pop#Connection.RawQuery

    Inside your Buffalo actions you could do something like this:

    func (v myResource) MyMethod(c buffalo.Context) error {
        // Get the DB connection from the context
        tx, ok := c.Value("tx").(*pop.Connection) // you get your connection here
        if !ok {
            return errors.WithStack(errors.New("no transaction found"))
        }
        q := tx.RawQuery("select * from foo where id = ?", 1) // you make your query here
        if err := q.All(model); err != nil {
            return errors.WithStack(err)
        }
    }
    

    This would be a solution to use Pop but not the predefined models. In that case you just use the connection which comes with the Buffalo context.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 想用@vueuse 把项目动态改成深色主题,localStorge里面的vueuse-color-scheme一开始就给我改成了dark,不知道什么原因(相关搜索:背景颜色)
  • ¥20 OPENVPN连接问题
  • ¥15 flask实现搜索框访问数据库
  • ¥15 mrk3399刷完安卓11后投屏调试只能显示一个设备
  • ¥100 如何用js写一个游戏云存档
  • ¥15 ansys fluent计算闪退
  • ¥15 有关wireshark抓包的问题
  • ¥15 需要写计算过程,不要写代码,求解答,数据都在图上
  • ¥15 向数据表用newid方式插入GUID问题
  • ¥15 multisim电路设计