登录
首页 >  Golang >  Go问答

为什么使用 gorm 连接 postgresql 时会出现 pq: 语法错误?

来源:stackoverflow

时间:2024-03-12 16:15:31 355浏览 收藏

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《为什么使用 gorm 连接 postgresql 时会出现 pq: 语法错误?》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

select_query = `select * from events where c_id = ? and start_time > ? and
                                    end_time < ?`

query := sr.db.raw(select_query, request.getcid(), starttime, endtime)

    var v = request.getvids()
    if len(v) > 0 {
        query = query.where(` v_id in (?) `, v)
    } //only this block introduces first ) after end_time

var c = request.getstatus().string()
    if len(c) > 0 {
        query = query.where( " status = ? ", c) // this introduces the other opening brace //after and
    }

以下是生成并在日志中找到的查询

SELECT * FROM events WHERE c_id = 1 AND start_time > '2020-04-16 18:42:00' and
                                        end_time < '2020-04-16 18:45:50' ) AND ( v_id IN (1,2)) AND ( status = 'STATUS_MIDDLE_CLASS'  ORDER BY  start_time DESC  LIMIT 5 OFFSET 1

stackoverflow 和互联网文章中的其他解决方案没有帮助。

ps:是不是因为我混合了 db.raw( ) 和 query.where() ?


解决方案


改变? 1 美元并不能解决问题。

基本上,一些事情解决了这个问题。

1) 混合 rawquery.where 是一个问题。

sr.db.where 进行 raw 查询后

2)

select_query = `select * from events where c_id = ? and start_time > ? and
                                    end_time < ?`

已经有 select * from。然后使用 query := sr.db.raw(select_query, request.getcid(), starttime, endtime) 引入嵌套 select *.

因此,将 select_query 更改如下

SELECT_QUERY = `events WHERE c_id = ? AND start_time > ? and
                                    end_time < ?`

解决了问题。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《为什么使用 gorm 连接 postgresql 时会出现 pq: 语法错误?》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>