node-adodb-extended
Version: 
A Node.js JavaScript Client implementing the ADODB protocol.
223 lines (171 loc) • 7.05 kB
Markdown
> 一个在 Windows 上实现 ADODB 协议的 Node.js JavaScript 客户端。
> 注意:这是一个社区维护的版本,已更新,添加了查询返回的其他格式。衷心感谢原作者 nuintun,他的工作只是被扩展,而不是被取代。感谢 nuintun 的努力。
> 一个用 Node.js 实现的 windows 上的 ADODB 协议。
>
> [![NPM Version][npm-image]][npm-url]
> [![Download Status][download-image]][npm-url]
> [![Windows Status][appveyor-image]][appveyor-url]
> [![Test Coverage][coveralls-image]][coveralls-url]
> ![Node Version][node-image]
> [![Dependencies][david-image]][david-url]
[](https://nodei.co/npm/node-adodb-extended/)
```js
'use strict';
const ADODB = require('node-adodb-extended');
const connection = ADODB.open('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=node-adodb.mdb;');
// 交易
connection
  .transaction([`INSERT INTO Users(UserId, UserName, UserSex, UserBirthday, UserMarried) VALUES (10, "Tom", "Male", "1981/5/10", 0);`,
          `INSERT INTO Users(UserId, UserName, UserSex, UserBirthday, UserMarried) VALUES (11, "Brenda", "Female", "2001/1/11", 0);`,
          `INSERT INTO Users(UserId, UserName, UserSex, UserBirthday, UserMarried) VALUES (10, "Bill", "Male", "1991/3/9", 0);`])
  .then(data => {
    console.log("我们不会到达,因为生成了重复的ID。遇到错误时,请勿插入任何记录。");
  })
  .catch(error => {
    console.error(error);
  });
// 不带返回的执行
connection
  .execute('INSERT INTO Users(UserName, UserSex, UserAge) VALUES ("Newton", "Male", 25)')
  .then(data => {
    console.log(JSON.stringify(data, null, 2));
  })
  .catch(error => {
    console.error(error);
  });
// 带返回标识的执行
connection
  .execute('INSERT INTO Users(UserName, UserSex, UserAge) VALUES ("Newton", "Male", 25)', 'SELECT @@Identity AS id')
  .then(data => {
    console.log(JSON.stringify(data, null, 2));
  })
  .catch(error => {
    console.error(error);
  });
// 带返回的查询
connection
  .query('SELECT * FROM Users')
  .then(data => {
    console.log(JSON.stringify(data, null, 2));
  })
  .catch(error => {
    console.error(error);
  });
// 查询返回的对象数组
connection
  .query_v2('SELECT * FROM Users', false)
  .then(data => {
    console.log(JSON.stringify(data, null, 2));
  })
  .catch(error => {
    console.error(error);
  });
// 返回数组数组的查询
connection
  .query_v2('SELECT * FROM Users', true)
  .then(data => {
    console.log(JSON.stringify(data, null, 2));
  })
  .catch(error => {
    console.error(error);
  });
// 带字段描述的查询
connection
  .schema(20)
  .then(schema => {
    console.log(JSON.stringify(schema, null, 2));
  })
  .catch(error => {
    console.error(error);
  });
```
```js
'use strict';
const ADODB = require('node-adodb');
const connection = ADODB.open('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=node-adodb.mdb;');
async function query() {
  try {
    const users = await connection.query('SELECT * FROM Users');
    console.log(JSON.stringify(users, null, 2));
  } catch (error) {
    console.error(error);
  }
}
query();
async function query_v2(FetchArrays) {
  try {
    const users = await connection.query('SELECT * FROM Users', FetchArrays);
    console.log(JSON.stringify(users, null, 2));
  } catch (error) {
    console.error(error);
  }
}
query_v2(false);
// Will return a typed structure.
// key **type** == false. Indicates the returned structure.
// key **ResultSet** is an array of objects (records). (Identical to original query but within the recorrd).
query_v2(true);
// Will return a typed object.
// key **type** == true. Indicates the returned structure.
// key **ResultSet['FieldMetaData']['FieldName']** is an array of strings.
// key **ResultSet['FieldMetaData']['FieldType']** is an array of data types.
// key **ResultSet['ResultSet']** is an array of arrays.
```
`ADODB.open(connection[, x64]): ADODB`
> 初始化数据库链接参数。
`ADODB.query(sql): Promise`
`ADODB.query_v2(sql[, FetchArrays = false]): Promise`
> 执行有返回值的 SQL 语句。
`ADODB.execute(sql[, scalar]): Promise`
> 执行无返回值或者带更新统计的的 SQL 语句。
`ADODB.transaction(sql[]): Promise`
> 执行多个SQL语句作为事务。
`ADODB.schema(type[, criteria][, id]): Promise`
> 查询数据库架构信息。参考: [OpenSchema](https://docs.microsoft.com/zh-cn/sql/ado/reference/ado-api/openschema-method)
> 设置环境变量 `DEBUG=ADODB`。参考: [debug](https://github.com/visionmedia/debug)
> 该类库理论支持 Windows 平台下所有支持 ADODB 连接的数据库,只需要更改数据库连接字符串即可实现操作!
> 数据库连接字符串:
>
> - Access 2000-2003 (\*.mdb): `Provider=Microsoft.Jet.OLEDB.4.0;Data Source=node-adodb.mdb;`
> - Access > 2007 (\*.accdb): `Provider=Microsoft.ACE.OLEDB.12.0;Data Source=adodb.accdb;Persist Security Info=False;` 或者   `Provider=Microsoft.ACE.OLEDB.15.0;Data Source=adodb.accdb;Persist Security Info=False;`
> 该类库需要系统支持 `Microsoft.Jet.OLEDB.4.0` 或者 `Microsoft.ACE.OLEDB.12.0`,对于 `Windows XP SP2` 以上系统默认支持 `Microsoft.Jet.OLEDB.4.0`,其它需要自己安装支持!
>
> 推荐使用 `Microsoft.ACE.OLEDB.12.0`,获取地址: [Microsoft.ACE.OLEDB.12.0](https://www.microsoft.com/zh-CN/download/details.aspx?id=13255)
> 如果你想在 `ASAR` 包中运行这个模块,你需要做一些修改。
> 1. 从 `asar` 包中排除 `adodb.js`(使用 `electron-builder`, 可以配置 `extraResources` 将制定文件排除在外)
```json
"extraResources": [
  {
    "from": "./node_modules/node-adodb/lib/adodb.js",
    "to": "adodb.js"
  }
]
```
> 2. 告诉 `asar` 从哪里运行 `adodb.js` (可以将配置写在 `Electron` 的 `main.js` 文件中)
```javascript
// Are we running from inside an asar package ?
if (process.mainModule.filename.indexOf('app.asar') !== -1) {
  // In that case we need to set the correct path to adodb.js
  ADODB.PATH = './resources/adodb.js';
}
```
[]: https://img.shields.io/npm/v/node-adodb.svg?style=flat-square
[]: https://www.npmjs.org/package/node-adodb
[]: https://img.shields.io/npm/dm/node-adodb.svg?style=flat-square
[]: https://img.shields.io/appveyor/ci/nuintun/node-adodb/master.svg?style=flat-square&label=windows
[]: https://ci.appveyor.com/project/nuintun/node-adodb
[]: http://img.shields.io/coveralls/nuintun/node-adodb/master.svg?style=flat-square
[]: https://coveralls.io/r/nuintun/node-adodb?branch=master
[]: https://img.shields.io/david/nuintun/node-adodb.svg?style=flat-square
[]: https://david-dm.org/nuintun/node-adodb
[]: https://img.shields.io/node/v/node-adodb.svg?style=flat-square