登录
首页 >  Golang >  Go问答

使用 Go 修改 postgres 中等于 (=) 为不等于 (<>) 的方法

来源:stackoverflow

时间:2024-03-18 13:18:30 295浏览 收藏

在 Go 中修改 PostgreSQL 查询时,如果需要将等于 (=) 运算符修改为不等于 (),可以使用以下优雅的方法:定义一个运算符类型和常量,通过字符串连接或 fmt.Sprintf() 构建查询字符串,并更改函数签名以接受运算符作为参数。这种方法简化了查询的修改过程,使代码更具可读性和可维护性。

问题内容

我有两个非常相似的 sql 查询。唯一的区别是,在其中一个 where 子句中,我使用等于 (=),而不是不等于 (<>)。有没有一种方法可以以优雅的方式以编程方式修改查询?我正在寻找这样的东西:

func getEvents(name string, exclude bool) {
    q := `SELECT * FROM events WHERE name`
    if exclude {
        q = q + " <> "
    } else {
        q = q + " = "
    }
    q = q + "$1"

    result, err := DBQuery(q, name)
    ...
}

解决方案


一种优雅的方法是为运算符创建类型和常量:

type op string

const (
    opequal       op = "="
    opnotequal    op = "<>"
    oplessthan    op = "<"
    opgreaterthan op = ">"
    // ... any other ops you need
)

然后构建查询字符串是一个简单的字符串连接:

q := "select * from events where name" + op + "$1"

或者您可以使用fmt.Sprintf()

q := fmt.sprintf("select * from events where name %s $1", op)

当然将 getevents() 的签名更改为:

func getevents(name string, op op)

调用 getevents() 现在更好了:

getEvents("error", OpEqual)
getEvents("error", OpNotEqual)

尝试 Go Playground 上的示例。

终于介绍完啦!小伙伴们,这篇关于《使用 Go 修改 postgres 中等于 (=) 为不等于 () 的方法》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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