登录
首页 >  Golang >  Go问答

在 PostgreSQL 中没有所谓的 PSQL 运算符

来源:stackoverflow

时间:2024-03-03 19:09:23 116浏览 收藏

最近发现不少小伙伴都对Golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《在 PostgreSQL 中没有所谓的 PSQL 运算符》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

问题内容

这是我的原始查询,它在 pg_admin 中针对同一数据库工作:

with myconstants (nb_pieces,nb_room,is_fiber) as (
        values (0,0,true)
 )
select 
    pbuy.name, seller.name as seller_name, fiche.fiber
from 
    on_plan_buy pbuy
inner join
      card_fiche fiche
      on pbuy.uuid = fiche.ad_uuid
inner join
     on_plan_seller seller
     on pbuy.seller_id = seller.id
inner join
        myconstants conste
        on true
where pbuy.code_insee in ('92108','75018')
        and pbuy.price <= 9999999 and pbuy.price >= 0
        and case when conste.is_fiber = false then true else fiche.fiber = true end
limit 100;

但是当我在 golang 中这样做时:

query = `
with myconstants (nb_pieces,nb_room,is_fiber) as (
    values ($3,$4,$5)
 )
select 
    pbuy.name
from 
    ` + tableonplan + ` pbuy
inner join
    card_fiche fiche
    on pbuy.uuid = fiche.ad_uuid
inner join
    myconstants conste
    on true
where pbuy.code_insee in ('` + strings.join(gsm.codeinsee, "','") + `')
    and pbuy.price <= $1 and pbuy.price >= $2
    and case when conste.is_fiber = false then true else fiche.fiber = true end
limit 100;
`
//and case when conste.nb_pieces = 0 then pbuy.piece > 0 else pbuy.piece = conste.nb_pieces end
//and case when conste.nb_room = 0 then pbuy.chambre > 0 else pbuy.chambre = conste.nb_room end
//and case when conste.is_fiber = false then true else fiche.fiber = true end
fmt.println(query)
err = db.select(&response.offers, query, gsm.pricemax, gsm.pricemin, gsm.nbroom, gsm.nbchamber, gsm.fiber)

使用此 gsm 结构:

type getsearchmsg struct {
    adresse          string   `json:"adresse"`
    codeinsee        []string `json:"code_insee"`
    m2               int      `json:"m2"`
    pricemin         int      `json:"price_min"`
    pricemax         int      `json:"price_max"`
    type             string   `json:"type"`
    nbroom           int      `json:"nb_room"`
    nbchamber        int      `json:"nb_chamber"`
    typeconstruction string   `json:"typeconstruction"`
    typetravel       string   `json:"type_travel"`
    geoid            string   `json:"geo_id"`
    timetravel       string   `json:"time_travel"`
    fiber            bool     `json:"fiber"`
}

我有一个:

ERRO[0002] pq: operator does not exist: text = boolean   error=TestError
panic: pq: operator does not exist: text = boolean

当我在 ide 中滚动 gsm. fiber 时,它仍然告诉我 gsm. fiber 是一个布尔值。

我可能有一个解决方案,可以将查询与 gsm.optical 的字符串值连接起来,但它不是很优雅。


正确答案


我猜 postgresql 不知道你的 cte 中的列是什么类型。当您在 pg_admin 中说出以下内容时:

with myconstants (nb_pieces,nb_room,is_fiber) as (
    values (0,0,true)
)

每个人都知道 true 是一个布尔值,所以一切正常。但是当你在 go 中使用它时:

with myconstants (nb_pieces,nb_room,is_fiber) as (
    values ($3,$4,$5)
)

驱动程序可能不知道要使用什么类型,因此它使用 text 表示 $5,因此 conste.is_ fiber 具有文本类型,并且 conste.is_ fiber = false 最终尝试将 textbooleanzqbendc 进行比较zqb。

您应该能够通过一些转换来解决这个问题:

WITH myconstants (nb_pieces, nb_room, is_fiber) as (
    values ($3::int, $4::int, $5::boolean)
)

本篇关于《在 PostgreSQL 中没有所谓的 PSQL 运算符》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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