【问题标题】:Log specific postgresql query using pg-promise使用 pg-promise 记录特定的 postgresql 查询
【发布时间】:2017-10-02 12:09:27
【问题描述】:

我正在使用带有 Nodejs 的 pg-promise 包来执行 PostgreSQL 查询。我想查看执行的查询。只有特定的查询,比如我想要调试的一个查询。

我可以看到,一种推荐的方法是使用pg-monitor 来捕获事件并记录它们,如示例documentation 中所述。

不使用pg-monitor,是否有一种简单的方法可以打印已执行的准备好的查询。我在文档中看不到。

例子:

db.query("SELECT * FROM table WHERE id = $/id/", {id: 2})

如何打印这个查询来产生?

SELECT * FROM table WHERE id = 2

【问题讨论】:

    标签: node.js postgresql pg-promise


    【解决方案1】:

    有没有一种简单的方法来打印已执行的准备好的查询...

    一般的查询 - 是的,见下文。 Prepared Query - 不,根据定义,这些是在服务器端格式化的。

    const query = pgp.as.format('SELECT * FROM table WHERE id = $/id/', {id: 2});
    console.log(query);
    await db.any(query);
    

    如果您想打印模块执行的所有查询,而不使用pg-monitor,只需在初始化库时添加事件query 处理程序:

    const initOptions = {
      query(e) {
        console.log(e.query);
      }
    };
    const pgp = require('pg-promise')(initOptions);
    

    【讨论】:

    • options 很棒。我还没有完全探索它。谢谢。
    • 不确定这个问题可能与选项有关 - 为了更快地在此处发表评论。请检查。谢谢 - stackoverflow.com/questions/65152018/…
    猜你喜欢
    • 1970-01-01
    • 2016-07-14
    • 2020-08-03
    • 1970-01-01
    • 2018-02-19
    • 1970-01-01
    • 2018-04-12
    • 1970-01-01
    相关资源
    最近更新 更多