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();
我以用户 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();