对此我一直在挠头。我想知道是否有一种有效的方法来创建一个Mysql连接,并在Express服务的应用程序中的不同模块之间共享它。到目前为止,我在所有需要某种数据库连接的JS文件的顶部都有以下代码:
const db = require('mysql2')
pool = db.createPool(<config details>)
// Below
pool.execute(.. ) // etc
我觉得这有点过头了。有没有办法创建一个连接,比如在express app中?或者一个单独的文件,然后在我需要的时候检索该连接?我是这样想的:
// In db.js
const db = require('mysql2')
module.exports = db.createPool(<config details>)
// In file1.js that needs a db connection
let db = require('./db')
db.execute(...)
// In file2.js
let db = require('./db')
db.execute(...)
诸若此类。谢谢你们的帮助。
发布于 2018-07-19 04:18:31
嗯,多亏了@paul,我想通了。我在放置MySQL连接的位置创建了一个dB文件,并将其导出,以便需要该连接的其他文件可以简单地使用它。
// dB.sql
let MySQL = require(‘mysql2’)
module.exports = MySQL.createPool(require(‘./config’)
因此,包含上述文件的任何文件都可以访问该连接。
// File that needs pool instance
let pool = require(‘path to dB file’)
我希望这对任何正在寻找类似解决方案的人都有所帮助。
干杯!
https://stackoverflow.com/questions/51409922
复制相似问题