首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >节点-mysql2 2使用conn.release()和conn.end()

节点-mysql2 2使用conn.release()和conn.end()
EN

Stack Overflow用户
提问于 2016-09-28 15:52:22
回答 1查看 5.7K关注 0票数 7

在这里查看异步/等待示例:

代码语言:javascript
复制
https://github.com/sidorares/node-mysql2/blob/master/documentation/Promise-Wrapper.md

作者使用c.end()

代码语言:javascript
复制
   let mysql = require('mysql2/promise');
   let pool = mysql.createPool({database: test});
   // execute in parallel, next console.log in 3 seconds
   await Promise.all([pool.query('select sleep(2)'), pool.query('select sleep(3)')]);
   console.log('3 seconds after');
   await pool.end();
   await conn.end();

然而,仅在上面几行,他使用了conn.release()

代码语言:javascript
复制
pool.getConnection()
     .then((conn) => {
       var res = conn.query('select foo from bar');
       conn.release();
       return res;
     })

一旦我们使用了连接对象,我们将使用什么?

应该是conn.release()还是conn.end()?

EN

回答 1

Stack Overflow用户

发布于 2016-09-28 17:55:54

这些例子并不意味着要做同样的事情。而且,第一个示例(在您的代码中)引用了一个变量(conn),它从未使用过。我认为这只是示例代码中的一个错误。

第一个示例演示如何创建池,运行两个并发查询(使用池),等待所有查询完成,然后清理。就像我之前说过的,conn.end()在那里是没有意义的。

第二个示例向您展示了如何从池中请求一个空闲连接,使用该连接运行一个查询(由承诺res表示),将连接返回到池(通过调用conn.release()),然后将结果传播到允诺链。

第二个示例可以重写如下:

代码语言:javascript
复制
let conn = await pool.getConnection();
let res  = conn.query('select foo from bar');

conn.release();

let result = await res;

因此,conn.release()用于将连接释放回连接池。它不会关闭连接,它只是使它可以用于其他查询。

conn.end() (我假设)关闭了连接,我想您应该只在自己显式创建连接时才调用它(与从池中检索到的连接不同,池应该由池来管理)。

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

https://stackoverflow.com/questions/39752267

复制
相关文章

相似问题

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