BETA
Это Node.js пакет для выполнения SQL-запросов к базам данных MS Access. Предназначен для использования на Windows XP и старше. В режиме "клиент-сервер" клиентская часть может использоваться без ограничения операционной системы.
Для подключения из приложений Node.js к базам данных в формате MS Access.
node-adodb. Идея подключения из Node.js к ADODB.Connection через JScript почерпнута оттуда. Настоящий пакет фактически является переделкой node-adodb, c целью добавления новых возможностей и устраненния недостатков.
Node.js запускает (spawn) процесс Windows Script Host для выполнения небольшого JScript, который фактически и выполняет SQL-запрос с помощью ADODB.Connection. Данные между процессами передаются через стандартные потоки ввода-вывода: stdin, stdout, sterr.
Windows XP, 7, Vista, 8, 8.1, 10, Node.js v.4.x (более старшие версии Node.js не тестировались, поскольку не работают на Windows XP), Microsoft.Jet.OLEDB.4.0. В случае использования пакета в режиме "клиент-сервер" системные требования действительны для только серверной части. Клиентская часть не использует специфичный для Windows код.
- Расширен синтаксис SQL:
- разрешены комментарии в коде
- TODO несколько операторов через ";" (multiple statements)
- Работа в режиме клиент-сервер.
- Турбо-режим, т.е. использование Recordset.GetString() вместо Recordset.MoveNext(), что значительно ускоряет выполнение SQL-запросов, особенно с большим количеством столбцов. Применять турбо-режим можно только с оговоркой, что в возвращаемых данных гарантировано отсутствует символ табуляции (символ табуляции используется процедурой Recordset.GetString() для разделения строк и столбцов). TODO Отлючение турбо-режима для применения пакета без оговорок.
- TODO Потоковый (stream) режим возвращения результатов SQL-запроса.
npm install adodb --save
const ADODB = require('adodb');
const connStr = 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Northwind2003.mdb';
// if you have installed server connection string can be like this
// const connStr = 'Provider=Adodb-server;Host=127.0.0.1;Port=4023'
const pool = ADODB.createPool(connStr);
pool.query('SELECT * FROM Categories;', (err, data) => {
if (err) {
console.error(err.message);
} else {
console.log(data);
}
pool.end();
});
C:\>npm install adodb -g
C:\>mkdir adodb-config
C:\>cd adodb-config
C:\adodb-config>adodb run
ADODB_PATH: undefined
config file: C:\adodb\adodb-config.json
opened server on {"address":"::","family":"IPv6","port":4023}
Ctrl+C
^CЗавершить выполнение пакетного файла [Y(да)/N(нет)]? y
В текущем каталоге будет создан файл adodb-config.json
.
Его небходимо отредактировать, указав порт и строку подключения к базе данных MS Access.
При наличии системной переменной ADODB_PATH
файл adodb-config.json
будет создан в каталоге,
указанном этой системной переменной.
C:\adodb-config>adodb run
C:\>telnet localhost 4023
connStr: Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Data Source=C:\node487\node_modules\adodb\test\media\Northwind2003.mdb
endStr: END{6251729b-82fb-4b89-9bf8-d550c78acd3f}
LOCALS
{"OEMCP":"866","ACP":"1251","sDecimal":",","sShortDate":"yyyy-MM-dd","sTimeFormat":"H:m:s"}
END{6251729b-82fb-4b89-9bf8-d550c78acd3f}
testing db connection: OK
CTRL+]
Microsoft Telnet> q
C:\>
C:\adodb-config>adodb install
C:\adodb-config>adodb uninstall
C:\adodb-config>adodb
const ADODB = require('adodb');
const connStr = 'Provider=Adodb-server;Host=127.0.0.1;Port=4023'
const pool = ADODB.createPool(connStr);
pool.query('SELECT * FROM Categories;', (err, data) => {
if (err) {
console.error(err.message);
} else {
console.log(data);
}
pool.end();
});