ORA-00900: 无效 SQL 语句 - 当 运行 使用 node-oracledb 的查询时

ORA-00900: invalid SQL statement - when run a query using node-oracledb

我以用户 AN 身份登录并在 sql 开发人员中创建了一个过程:

CREATE OR REPLACE PROCEDURE **viewSystemUsers**
AS 
  sysRefCursor SYS_REFCURSOR;
BEGIN
  OPEN sysRefCursor
  FOR 
    SELECT USERNAME, USER_ID, PASSWORD FROM dba_users;
    dbms_sql.return_result(sysRefCursor);
END;

执行了它,这一切正常。之后我成功连接作为同一用户使用node-oracledb:

  oracle.getConnection(
        {
            user : "AN",
            password: "AN123",
            connectString: "localhost:1521/orcl"
            
        }, 
        (error, **connection**) => {
                if(error){
                    console.error(error.message);
                    return;
                }
                else
                    console.log('connect sucessfully!');
                    

但是当我设置 EXECUTE 查询时:

**connection**.execute(
      `execute **viewSystemUsers**;`,
       (err, result) => {
            if(err){
                  console.error(err);
                  return;
            }
           console.log(result);

我收到了 [错误:ORA-00900:无效的 SQL 语句] { errorNum: 900, offset: 0 }。 任何人都可以帮我解决它吗?非常感谢。

  • 您正在将字符串 execute ... 传递给数据库。但是 execute 不是 SQL 关键字 - 它是 SQL*Plus 命令。所以数据库不理解它并给出错误。而是 begin viewSystemUsers() end;.

  • 为了便于编程使用 async/await,而不是回调

  • 查看 node-oracledb 示例 impres.js 因为它显示了隐式结果的使用(dbms_sql.return_result() 是什么)。

  • 查看 node-oracledb 示例 plsqlproc.js

你的代码可以是这样的:

const oracledb = require('oracledb');
const dbConfig = require('./dbconfig.js');

if (process.platform === 'darwin') {
  oracledb.initOracleClient({libDir: process.env.HOME + '/Downloads/instantclient_19_8'});
}

let sql, binds, options, result;
sql = `begin viewSystemUsers(); end;`;
binds = [];
options = { outFormat: oracledb.OUT_FORMAT_OBJECT };

async function run() {
  let connection;

  try {
    connection = await oracledb.getConnection(dbConfig);

    result = await connection.execute(sql, binds, options);
    console.dir(result, { depth: null });

  } catch (err) {
    console.error(err);
  } finally {
    if (connection) {
      try {
        await connection.close();
      } catch (err) {
        console.error(err);
      }
    }
  }
}

run();