使用 mariadb nodeJS 连接器进行多个查询

2023-12-10

我有一台运行 Node.js 的服务器连接到 MariaDb 数据库。我正在使用Node.js 连接器它对于单个查询工作得很好。但是,当我尝试执行多个查询时,它会抛出此错误:

{ Error: (conn=8439, no: 1064, SQLState: 42000) You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'SELECT 2' at line 1  
sql: SELECT 1; SELECT 2; - parameters:[]
 at Object.module.exports.createError (\node_modules\mariadb\lib\misc\errors.js:55:10)
 at Packet.readError (\node_modules\mariadb\lib\io\packet.js:506:19)
 at Query.readResponsePacket (\node_modules\mariadb\lib\cmd\resultset.js:47:28)
 at PacketInputStream.receivePacket (\node_modules\mariadb\lib\io\packet-input-stream.js:73:9)
 at PacketInputStream.onData (\node_modules\mariadb\lib\io\packet-input-stream.js:129:20)
 at Socket.emit (events.js:182:13)
 at addChunk (_stream_readable.js:283:12)
 at readableAddChunk (_stream_readable.js:264:11)
 at Socket.Readable.push (_stream_readable.js:219:10)
 at TCP.onStreamRead [as onread] (internal/stream_base_commons.js:94:17)
fatal: false,
errno: 1064,
sqlState: '42000',
code: 'ER_PARSE_ERROR' }

我当前使用的测试代码是:

conn = await pool.getConnection({multipleStatements: true});
conn.query({
  multipleStatements: true,
  sql: "SELECT 1; SELECT 2;"
}).then((data: any) => {
  console.log(data);
  conn.end();
});

The 文档建议multipleStatements是一个选项,但仔细查看GitHub 存储库,我发现它的唯一地方是在下面lib/config/connection-options.jsGitHub 文档。我还注意到批量选项但这似乎是专门针对大量插入的。

有没有办法使用 mariadb-connector-nodejs 在单个查询中运行多个查询query称呼?如果是这样,我还可能做错了什么,只有多语句查询不起作用?

版本:
- MariaDb:10.1.34-MariaDB
- Node.js:v10.14.2
- mariadb-连接器-nodejs:[电子邮件受保护]


multipleStatements是一个不错的选择,但正如@rolandstarke 所指出的,这是一个连接选项。

当使用创建池时,您指定池+连接选项,因为池将处理连接创建。参见相关文档

Example:

const mariadb = require("mariadb");
const pool = mariadb.createPool({ multipleStatements: true });

pool.query("select 1; select 2")
  .then(results => {
    //select 1 results
    console.log(results[0]); //{ '1': 1 }
    //select 2 results
    console.log(results[1]); //{ '2': 2 }
  })
  .catch(err => {
    //handle error
  });
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 mariadb nodeJS 连接器进行多个查询 的相关文章

随机推荐