Переменная привязки node-oracledb имеет значение null

Используя пакет node-oracledb с node.js, я пытаюсь удалить строку в моя база данных оракула, в которой есть значение null. Мне нужно иметь возможность передать значение null в качестве переменной связывания, но оно выдает ошибку:

var query = "delete from table where event IS :event";
var bind_vars = [null];
connection.execute(query, bind_vars, { autoCommit: true }, function(error, results) {});

Возвращаемая ошибка

{Ошибка: ORA-00908: отсутствует ключевое слово NULL errorNum: 908, смещение: 46}


person Kaiser Wilhelm    schedule 19.04.2018    source источник
comment
IS NULL — это два ключевых слова, а не ключевое слово+переменная. Поскольку значения привязки предназначены для переменных, вы не сможете выполнить привязку в этом контексте (как вы обнаружили).   -  person Christopher Jones    schedule 05.05.2020


Ответы (2)


Для этого вам не нужна переменная связывания...

Учитывая следующую таблицу:

create table t (
  c number
);

insert into t values (1);
insert into t values (null);
insert into t values (3);
insert into t values (null);
insert into t values (5);

commit;

Это должно работать:

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

async function runTest() {
  let conn;

  try {
    conn = await oracledb.getConnection(config);

    let result;
    let value = 1;

    if (value === null) {
      result = await conn.execute('delete from t where c is null');
    } else { // other values should have a bind
      result = await conn.execute('delete from t where c = :value', [value]);
    }

    // Note that the work was not committed.
    console.log('Rows deleted:', result.rowsAffected);
  } catch (err) {
    console.error(err);
  } finally {
    if (conn) {
      try {
        await conn.close();
      } catch (err) {
        console.error(err);
      }
    }
  }
}

runTest();
person Dan McGhan    schedule 19.04.2018
comment
Спасибо, Дэн. К сожалению, я создаю класс, который должен иметь возможность запрашивать несколько таблиц и быть достаточно гибким для обработки всех типов. Так что это не может быть жестко закодировано. По сути, я ищу способ передать переменную типа null в качестве привязки - person Kaiser Wilhelm; 19.04.2018
comment
Я не знаю, что вы подразумеваете под жестким кодом. Как ваш класс генерирует SQL? Почему бы не сгенерировать SQL, который использует правильные условия. См. Nulls с условиями сравнения: docs.oracle.com/en/database/oracle/oracle-database/18/sqlrf/. - person Dan McGhan; 20.04.2018

как насчет изменить запрос

var query = "delete from table where nvl(event, '__') = nvl(:event, '__')";
var bind_vars = [null];
connection.execute(query, bind_vars, { autoCommit: true }, function(error, results) {});

он меняет нулевой столбец и значение на другое изменение символа (__) с вашим собственным символом

person projo    schedule 04.05.2020