douyan3478 2018-11-13 14:47
浏览 674
已采纳

如何在PostgreSQL中跟踪SQL查询

sql.Register("sqlWithHooks", sqlhooks.Wrap(r.Driver(), &Hooks{}))

// Connect to the registered wrapped driver
db, err := sql.Open("sqlWithHooks", ":memory:")
if err != nil {
    fmt.Println("error",err)

}

rows, err := db.Query("SELECT id,name,zone_z_id,dimension,price FROM   gift_box_z ")

if err != nil {
    fmt.Println("inside the error .........................",err)

}

After running this code I am getting an error missing "=" after ":memory:" in connection info string. Can anyone tell me what's wrong with what I've done here?

  • 写回答

2条回答 默认 最新

  • dongyi2425 2018-11-13 19:34
    关注

    sql.Open() expects 2 things 'driverName' and 'dataSourceName'. In case of sqlhooks example, they used sqlite as database. Apart from that, they have used go-sqlite3 and if you look closely to file sqlite3.go at line number 886. You would see datasourcename ':memory:' that means we are opting for in-memory utilization of sqlite db.

    'dataSourceName' will vary as per the database opted. Its basically means connection string in Data Source Name format.

    Reason why this worked fmt.Sprintf("host=%s port=%d user=%s password=%s dbname=%s sslmode=disable", host, port, user, password, dbname)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 统信uos升级apt后启动失败
  • ¥15 求指导储层饱和度及含水率测井解释
  • ¥200 建三维地震工区写入sgy到指定目录
  • ¥30 靶向捕获测序探针设计自学
  • ¥15 写代码写代码单片机代码写代码写数字按键代码
  • ¥15 django按照距离进行排序
  • ¥15 (标签-微信|关键词-微信公众号)
  • ¥15 matlab中mjs用不了
  • ¥15 Ios抖音直播的时候如何添加自定义图片在直播间!
  • ¥60 riscv-pulpino总线上挂载axi从机