如何解决 Node JS 错误 - NJS-097: 在语句文本中找不到绑定占位符?

问题描述 投票:0回答:0

我在从 NodeJS 执行 Oracle 存储过程时遇到以下错误,需要帮助来解决它。

我能够在 sqldeveloper 中执行存储过程,没有任何问题,并且它返回预期结果。

NodeJS 代码:

const router = express.Router();

router.get('/activerequests', async (req, res, next) => {

    const entityName: string = req.body.entityName;
    const sortBy: string = req.body.sortBy;
    const sortOrder: string = req.body.sortOrder;
    const startIndex = req.body.startIndex | 0;
    const pageSize = req.body.pageSize | 50;
    const conn = createMyApvDBConnection(await requestdbconnpool);
    const sql = `BEGIN 
                    get_dashboard_active_request_records(:p_entityname, :p_sortby, :p_sortorder, :p_startindex, :p_pagesize, p_totalrecords, p_activerecords);
                END;`;

    try {
        const dbresult = await (await conn)?.execute(sql, {
            p_entityname: { dir: OracleDB.BIND_IN, val: entityName, type: OracleDB.STRING },
            p_sortby: { dir: OracleDB.BIND_IN, val: sortBy, type: OracleDB.STRING },
            p_sortOrder: { dir: OracleDB.BIND_IN, val: sortOrder, type: OracleDB.STRING },
            p_startindex: { dir: OracleDB.BIND_IN, val: startIndex, type: OracleDB.NUMBER },
            p_pagesize: { dir: OracleDB.BIND_IN, val: pageSize, type: OracleDB.NUMBER },
            p_totalrecords: { dir: OracleDB.BIND_OUT, type: OracleDB.NUMBER },
            p_activerecords: { dir: OracleDB.BIND_OUT, type: OracleDB.CURSOR }
        });
        res.send(dbresult?.outBinds);
    } catch (err) {
        logger.error(err);
        res.status(500).send(`Error while retrieving Active Request records. Please contact the Administrator.`);
    } finally {
        if (conn) {
            try {
                await (await conn)?.close();
            } catch (err) {
                logger.error('Error while closing database connection', err);
            }
        }
    }
});

存储过程

create or replace PROCEDURE get_dashboard_active_request_records (
    p_entityname     IN   VARCHAR2,
    p_sortby         IN   VARCHAR2,
    p_sortorder      IN   VARCHAR2,
    p_startindex     IN   NUMBER,
    p_pagesize       IN   NUMBER,
    p_totalrecords   OUT  NUMBER,
    p_activerecords  OUT  SYS_REFCURSOR
) AS
BEGIN
    
dbms_output.put_line( 'Entity Name - ' || p_entityname || ', Sort By - ' || p_sortby || ', Sort Order - ' || p_sortorder || ', Start Index - ' || p_startindex || ', Page Size - ' || p_pagesize);

v_reqstatus := 'PENDINGAPPROVAL';
SELECT 
    COUNT(*)INTO p_totalrecords
FROM
    requests
WHERE
    upper(requeststatus) = v_reqstatus
        AND ( ( upper(p_entityname) = 'ENT1' AND processtype IN ( 'PROC1', 'PROC2' ) )
            OR ( upper(p_entityname) = 'ENT2' AND processtype NOT IN ( 'PROC1', 'PROC2' ) ) );

dbms_output.put_line( 'Entity Name - ' || p_entityname || ', Total Active Requests: ' || p_totalrecords);

OPEN p_activerecords FOR 
SELECT
      requestnumber,
      requeststatus,
      requestor,
      pendingwith,
      processtype,
      actiondate
FROM
      requests
WHERE
      upper(requeststatus) = v_reqstatus
          AND ( ( upper(p_entityname) = 'ENT1' AND processtype IN ( 'PROC1', 'PROC2' ) )
              OR ( upper(p_entityname) = 'ENT2' AND processtype NOT IN ( 'PROC1', 'PROC2' ) ) )
ORDER BY
    ( CASE WHEN lower(p_sortorder) = 'desc' AND lower(p_sortby) = 'requestnumber' THEN requestnumber END ) DESC,
    ( CASE WHEN lower(p_sortorder) = 'asc' AND lower(p_sortby) = 'requestnumber' THEN requestnumber END ) ASC,
    ( CASE WHEN lower(p_sortorder) = 'desc' AND lower(p_sortby) = 'processtype' THEN processtype END ) DESC,    
    ( CASE WHEN lower(p_sortorder) = 'asc' AND lower(p_sortby) = 'processtype' THEN processtype END ) ASC,    
    ( CASE WHEN lower(p_sortorder) = 'desc' AND lower(p_sortby) =  'actiondate' THEN actiondate END ) DESC,
    ( CASE WHEN lower(p_sortorder) = 'asc' AND lower(p_sortby) =  'actiondate' THEN actiondate END ) ASC
OFFSET p_startindex ROWS FETCH NEXT p_pagesize ROWS ONLY;

END get_dashboard_active_request_records;

错误:

{“级别”:“错误”,“时间戳”:“2024-03-12T08:47:34.258Z”,“pid”:16136,“主机”:“localhost”,“node_version”:“v21.6.1” ,"err":{"type":"Error","message":"NJS-097: 在语句文本中未找到名为“:P_TOTALRECORDS”的绑定占位符","stack":"错误: NJS-097:在语句文本中找不到名为“:P_TOTALRECORDS”的绑定占位符 在 Object.throwErr (C

node.js oracle stored-procedures
© www.soinside.com 2019 - 2024. All rights reserved.