我正在尝试实现以下nodejs mysql数据库this https://medium.com/@mhagemann/create-a-mysql-database-middleware-with-node-js-8-and-async-await-6984a09d49f4教程。我知道
pool.query() 是 pool.getConnection() + 的快捷方式
连接.查询()+连接.释放()。
文章中数据库配置为:
var mysql = require('mysql')
var pool = mysql.createPool({
connectionLimit: 10,
host: 'localhost',
user: 'matt',
password: 'password',
database: 'my_database'
})
pool.getConnection((err, connection) => {
if (err) {
if (err.code === 'PROTOCOL_CONNECTION_LOST') {
console.error('Database connection was closed.')
}
if (err.code === 'ER_CON_COUNT_ERROR') {
console.error('Database has too many connections.')
}
if (err.code === 'ECONNREFUSED') {
console.error('Database connection was refused.')
}
}
if (connection) connection.release()
return
})
module.exports = pool
这可以用作:
pool.query('SELECT * FROM users', function (err, result, fields) {
if (err) throw new Error(err)
// Do something with result.
})
但是,我真的不明白这一点
if (connection) connection.release()
如果使用池自动释放连接,为什么我们需要这个?
一旦你这样做了pool.getConnection()
,您将从池中删除一个连接,然后您可以使用该连接,并且其他任何人都无法从池中访问该连接。使用完毕后,将其放回池中,以便其他人可以使用。
所以,不使用时pool.query()
(正如您所知,它会自动将其放回池中),您必须获得一个连接,用它做任何您想做的事情,然后自己将其放回池中。
如果您需要做的只是一个查询,那么使用pool.query()
并让它自动从池中获取连接,运行查询,然后将其释放回池中。但是,如果您想使用连接执行多项操作,例如多次查询或多次插入数据库,则获取连接,使用它执行多个操作,然后将其释放回池。从池中手动获取连接还允许您在该连接上建立状态并在多个操作之间共享该状态。连续两次致电pool.query()
实际上可能使用池中的不同连接。它们甚至可能并行运行。
但是,我真的不明白这一点
if (connection) connection.release()
如果使用池自动释放连接,为什么我们需要这个?
如果您手动从池中获取连接,则在使用完毕后必须手动将其放回池中connection.release()
。否则,池中的连接很快就会清空,并且您将拥有一堆任何人都无法使用的空闲连接。
如果您使用像这样的自动方法pool.query()
,然后它将在单个查询操作后处理将其放回池中。
将其视为自动模式与手动模式。手动模式可以让您更好地控制自己的工作方式,但当自动模式符合您的需求时,它会更容易使用。当自动模式(pool.query()
)并不完全符合您的要求,然后手动从池中获取连接,使用它并将其放回。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)