首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在Mysql应用程序中的多个文件中使用一个NodeJS池连接

如何在Mysql应用程序中的多个文件中使用一个NodeJS池连接
EN

Stack Overflow用户
提问于 2018-07-19 03:45:55
回答 1查看 915关注 0票数 0

对此我一直在挠头。我想知道是否有一种有效的方法来创建一个Mysql连接,并在Express服务的应用程序中的不同模块之间共享它。到目前为止,我在所有需要某种数据库连接的JS文件的顶部都有以下代码:

代码语言:javascript
复制
const db = require('mysql2')
pool = db.createPool(<config details>)

// Below
pool.execute(.. ) // etc

我觉得这有点过头了。有没有办法创建一个连接,比如在express app中?或者一个单独的文件,然后在我需要的时候检索该连接?我是这样想的:

代码语言:javascript
复制
// 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(...)

诸若此类。谢谢你们的帮助。

EN

回答 1

Stack Overflow用户

发布于 2018-07-19 04:18:31

嗯,多亏了@paul,我想通了。我在放置MySQL连接的位置创建了一个dB文件,并将其导出,以便需要该连接的其他文件可以简单地使用它。

代码语言:javascript
复制
// dB.sql
let MySQL = require(‘mysql2’)
module.exports = MySQL.createPool(require(‘./config’)

因此,包含上述文件的任何文件都可以访问该连接。

代码语言:javascript
复制
// File that needs pool instance
let pool = require(‘path to dB file’)

我希望这对任何正在寻找类似解决方案的人都有所帮助。

干杯!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51409922

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档