javascript - 在 pg-promise API 中动态选择数据库/表
问题描述
pg-promise API 推荐一个初始连接对象,如:
var pgp = require('pg-promise')();
const mysqlcon = `postgres://${process.env.DB_USER}:${process.env.DB_PASSWORD}@${process.env.DB_HOST}:5432/my_database}` //note that 'my_database' is hardcoded here
var db = pgp(mysqlcon);
module.exports = db;
然后我使用这个对象来查询my_database数据库中的table_customers:
var db = require('./models/postgres')
db.many('SELECT * from table_customers')
.then(function (data) {
console.log('DATA:', data)
})
.catch(function (error) {
console.log('ERROR:', error)
})
这工作得很好,但是如果我要从另一个数据库中选择另一个表,我如何动态修改连接对象以将my_database更改为another_database?
解决方案
PostgreSql 中的连接是数据库绑定的,因此您只需使用两个数据库对象:
const mySqlCon1 = `postgres://.../database1`;
const mySqlCon2 = `postgres://.../database2`;
export const db1 = pgp(mySqlCon1);
export const db2 = pgp(mySqlCon2);
推荐阅读
- java - 需要帮助让数字一直翻倍到中间
- pdf - 尝试创建 PDF 可见签名时出现“对象标签格式错误”
- angular - 角度 7 路由状态无法获取传递的数据
- java - 保存 OneToMany 关系时总是得到无限递归(已使用 @JsonBackReference 和 @JsonManagedReference)
- python - 在随机选择一行时忽略 .txt 文件中的某些行
- powershell - 在 PowerShell 脚本中调用其他 PowerShell 脚本
- postgresql - Sequelize throwing:“关系“用户”不存在”
- php - 如何在 Moodle 3.5 中正确地需要依赖插件
- html - 如何在外部 CSS 文件 (.css) 中设置 lang 全局属性
- java - 使用 JNI 调用从 Cpp 返回字符串数组的 Java 方法