标签: node-oracle

使用node-oracle将硬编码字符串切成两半

我使用node-oracle连接到Oracle数据库.

当我从带有西里尔数据的表中选择值时,一切都很好,但如果我调用这样的procudure:

CREATE OR REPLACE PROCEDURE TEST_ENCODING (CUR OUT SYS_REFCURSOR) AS 
BEGIN
  open cur for
    select '????' as hello from dual; -- cyrillic hardcoded text
END TEST_ENCODING;
Run Code Online (Sandbox Code Playgroud)

然后从节点调用它:

connection.execute("call TEST_ENCODING(:1)", [new oracle.OutParam(oracle.OCCICURSOR)],
  function (err, result) {
    console.log(result)
  }
);
Run Code Online (Sandbox Code Playgroud)

结果是:( [ { HELLO: '??' } ]字符串被切成两半).

数据库配置如下:

NLS_LANGUAGE    AMERICAN
NLS_TERRITORY   AMERICA
NLS_CURRENCY    $
NLS_ISO_CURRENCY    AMERICA
NLS_NUMERIC_CHARACTERS  .,
NLS_CHARACTERSET    CL8MSWIN1251
NLS_CALENDAR    GREGORIAN
NLS_DATE_FORMAT DD-MON-RR
NLS_DATE_LANGUAGE   AMERICAN
NLS_SORT    BINARY
NLS_TIME_FORMAT HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT    DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT  HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT …
Run Code Online (Sandbox Code Playgroud)

oracle node.js node-oracle

6
推荐指数
1
解决办法
1034
查看次数

标签 统计

node-oracle ×1

node.js ×1

oracle ×1