登录
首页 >  Golang >  Go问答

pq:在使用 vscode 访问 postgres 时,尝试验证用户“用户名”的密码时失败了

来源:stackoverflow

时间:2024-02-10 09:24:25 390浏览 收藏

哈喽!今天心血来潮给大家带来了《pq:在使用 vscode 访问 postgres 时,尝试验证用户“用户名”的密码时失败了》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!

问题内容

我正在使用 golang 制作 api,并使用 postgres 作为数据库。我使用了以下命令:-

args := "host=" + host + " port=" + port + " dbName=" + dbName + "username=" + username + " sslmode=disable password=" + password
    db, err := gorm.Open("postgres", args)
    if err != nil {
        log.Fatal(err)
    }
db.AutoMigrate(models.Hospital{})
    DB = db

但是当我构建模型时,我收到错误:-

pq:用户“ansh joshi” 密码验证失败

虽然当我尝试在 pgadmin 中使用相同的密码登录时,我能够完美地登录。然后我无法理解的是为什么我在使用 vscode 时无法连接它。

任何帮助将不胜感激。预先感谢您...


正确答案


我不确定您打开与 gorm 的连接的代码是否正确。

文档中是这样写的

dsn := "host=localhost user=gorm password=gorm dbname=gorm port=9920 sslmode=disable timezone=asia/shanghai"
db, err := gorm.open(postgres.open(dsn), &gorm.config{})

我建议您将 dsn 设置为 fmt.sprintf 以提高可读性。
因为你的user有空格,所以你应该在开始和结束user添加'

这是示例:

    args := fmt.Sprintf("host=%s port=%s dbname=%s user='%s' password=%s sslmode=%s", host, port, dbName, username, password, sslmode)
    fmt.Println(args)

    db, err := gorm.Open(postgres.Open(args), nil)
    if err != nil {
        log.Fatal(err)
    }

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

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