@sqb/mssql-dialect 4.2.1 → 4.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +67 -0
- package/cjs/index.js +5 -0
- package/{dist/MSSqlSerializer.js → cjs/ms-sql-serializer.js} +1 -3
- package/cjs/package.json +3 -0
- package/{dist → esm}/index.d.ts +0 -0
- package/esm/index.js +3 -0
- package/{dist/MSSqlSerializer.d.ts → esm/ms-sql-serializer.d.ts} +0 -0
- package/esm/ms-sql-serializer.js +31 -0
- package/package.json +48 -33
- package/dist/index.js +0 -5
package/README.md
ADDED
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
|
|
2
|
+
<p style="text-align:center">
|
|
3
|
+
<img src="https://user-images.githubusercontent.com/3836517/32965280-1a2b63ce-cbe7-11e7-8ee1-ba47313503c5.png" width="500px" alt="SQB Logo"/>
|
|
4
|
+
</p>
|
|
5
|
+
|
|
6
|
+
<br>
|
|
7
|
+
|
|
8
|
+
[![NPM Version][npm-image]][npm-url]
|
|
9
|
+
[![NPM Downloads][downloads-image]][downloads-url]
|
|
10
|
+
[![Build Status][travis-image]][travis-url]
|
|
11
|
+
[![Test Coverage][coveralls-image]][coveralls-url]
|
|
12
|
+
[![Dependencies][dependencies-image]][dependencies-url]
|
|
13
|
+
[![DevDependencies][devdependencies-image]][devdependencies-url]
|
|
14
|
+
[![Package Quality][quality-image]][quality-url]
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
## About SQB
|
|
18
|
+
|
|
19
|
+
SQB is an extensible, multi-dialect SQL query builder and Database connection wrapper for NodeJS.
|
|
20
|
+
|
|
21
|
+
## Main goals
|
|
22
|
+
|
|
23
|
+
- Single code base for any sql based database
|
|
24
|
+
- Powerful and simplified query coding scheme
|
|
25
|
+
- Fast applications with low memory requirements
|
|
26
|
+
- Let applications work with large data tables efficiently
|
|
27
|
+
- Support latest JavaScript language standards
|
|
28
|
+
- Lightweight and extensible framework.
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
You can report bugs and discuss features on the [GitHub issues](https://github.com/sqbjs/sqb/issues) page
|
|
32
|
+
|
|
33
|
+
Thanks to all of the great [contributions](https://github.com/sqbjs/sqb/graphs/contributors) to the project.
|
|
34
|
+
|
|
35
|
+
You may want to check detailed [DOCUMENTATION](https://sqbjs.github.io/sqb/)
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
## Installation
|
|
39
|
+
|
|
40
|
+
```bash
|
|
41
|
+
$ npm install @sqb/mssql-dialect --save
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
## Node Compatibility
|
|
45
|
+
|
|
46
|
+
- node >= 16.x
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
### License
|
|
50
|
+
SQB is available under [MIT](LICENSE) license.
|
|
51
|
+
|
|
52
|
+
[npm-image]: https://img.shields.io/npm/v/@sqb/mssql-dialect.svg
|
|
53
|
+
[npm-url]: https://npmjs.org/package/@sqb/mssql-dialect
|
|
54
|
+
[travis-image]: https://img.shields.io/travis/sqbjs/@sqb/mssql-dialect/master.svg
|
|
55
|
+
[travis-url]: https://travis-ci.org/sqbjs/@sqb/mssql-dialect
|
|
56
|
+
[coveralls-image]: https://img.shields.io/coveralls/sqbjs/@sqb/mssql-dialect/master.svg
|
|
57
|
+
[coveralls-url]: https://coveralls.io/r/sqbjs/@sqb/mssql-dialect
|
|
58
|
+
[downloads-image]: https://img.shields.io/npm/dm/@sqb/mssql-dialect.svg
|
|
59
|
+
[downloads-url]: https://npmjs.org/package/@sqb/mssql-dialect
|
|
60
|
+
[gitter-image]: https://badges.gitter.im/sqbjs/@sqb/mssql-dialect.svg
|
|
61
|
+
[gitter-url]: https://gitter.im/sqbjs/@sqb/mssql-dialect?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
|
|
62
|
+
[dependencies-image]: https://david-dm.org/sqbjs/@sqb/mssql-dialect/status.svg
|
|
63
|
+
[dependencies-url]:https://david-dm.org/sqbjs/@sqb/mssql-dialect
|
|
64
|
+
[devdependencies-image]: https://david-dm.org/sqbjs/@sqb/mssql-dialect/dev-status.svg
|
|
65
|
+
[devdependencies-url]:https://david-dm.org/sqbjs/@sqb/mssql-dialect?type=dev
|
|
66
|
+
[quality-image]: http://npm.packagequality.com/shield/@sqb/mssql-dialect.png
|
|
67
|
+
[quality-url]: http://packagequality.com/#?package=@sqb/mssql-dialect
|
package/cjs/index.js
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const builder_1 = require("@sqb/builder");
|
|
4
|
+
const ms_sql_serializer_js_1 = require("./ms-sql-serializer.js");
|
|
5
|
+
(0, builder_1.registerSerializer)(new ms_sql_serializer_js_1.MSSqlSerializer());
|
|
@@ -4,9 +4,7 @@ exports.MSSqlSerializer = void 0;
|
|
|
4
4
|
const builder_1 = require("@sqb/builder");
|
|
5
5
|
const reservedWords = ['comment'];
|
|
6
6
|
class MSSqlSerializer {
|
|
7
|
-
|
|
8
|
-
this.dialect = 'mssql';
|
|
9
|
-
}
|
|
7
|
+
dialect = 'mssql';
|
|
10
8
|
isReservedWord(ctx, s) {
|
|
11
9
|
return s && typeof s === 'string' &&
|
|
12
10
|
reservedWords.includes(s.toLowerCase());
|
package/cjs/package.json
ADDED
package/{dist → esm}/index.d.ts
RENAMED
|
File without changes
|
package/esm/index.js
ADDED
|
File without changes
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { SerializationType } from '@sqb/builder';
|
|
2
|
+
const reservedWords = ['comment'];
|
|
3
|
+
export class MSSqlSerializer {
|
|
4
|
+
dialect = 'mssql';
|
|
5
|
+
isReservedWord(ctx, s) {
|
|
6
|
+
return s && typeof s === 'string' &&
|
|
7
|
+
reservedWords.includes(s.toLowerCase());
|
|
8
|
+
}
|
|
9
|
+
serialize(ctx, type, o, defFn) {
|
|
10
|
+
switch (type) {
|
|
11
|
+
case SerializationType.SELECT_QUERY:
|
|
12
|
+
return this._serializeSelect(ctx, o, defFn);
|
|
13
|
+
case SerializationType.EXTERNAL_PARAMETER:
|
|
14
|
+
return this._serializeParameter(ctx, o, defFn);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
_serializeSelect(ctx, o, defFn) {
|
|
18
|
+
let out = defFn(ctx, o);
|
|
19
|
+
const limit = o.limit || 0;
|
|
20
|
+
const offset = Math.max((o.offset || 0), 0);
|
|
21
|
+
if (offset)
|
|
22
|
+
out += '\nOFFSET ' + offset + ' ROWS';
|
|
23
|
+
if (limit)
|
|
24
|
+
out += (!offset ? '\n' : ' ') + 'FETCH NEXT ' + limit + ' ROWS ONLY';
|
|
25
|
+
return out;
|
|
26
|
+
}
|
|
27
|
+
_serializeParameter(ctx, o, defFn) {
|
|
28
|
+
defFn(ctx, o);
|
|
29
|
+
return '@' + o.name;
|
|
30
|
+
}
|
|
31
|
+
}
|
package/package.json
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sqb/mssql-dialect",
|
|
3
3
|
"description": "SQB serialization extension for MS-SQL database",
|
|
4
|
-
"version": "4.
|
|
4
|
+
"version": "4.5.0",
|
|
5
5
|
"author": "Panates",
|
|
6
6
|
"contributors": [
|
|
7
|
-
"Eray Hanoglu <e.hanoglu@panates.com>"
|
|
7
|
+
"Eray Hanoglu <e.hanoglu@panates.com>",
|
|
8
|
+
"Ilker Gurelli <i.gurelli@panates.com>"
|
|
8
9
|
],
|
|
9
10
|
"license": "Apache-2.0",
|
|
10
11
|
"repository": {
|
|
@@ -12,41 +13,55 @@
|
|
|
12
13
|
"url": "https://github.com/sqbjs/sqb.git",
|
|
13
14
|
"directory": "packages/mssql-dialect"
|
|
14
15
|
},
|
|
15
|
-
"
|
|
16
|
-
"
|
|
17
|
-
"
|
|
18
|
-
"
|
|
19
|
-
"
|
|
20
|
-
"
|
|
21
|
-
"dialect",
|
|
22
|
-
"
|
|
23
|
-
"
|
|
24
|
-
|
|
16
|
+
"scripts": {
|
|
17
|
+
"compile": "tsc",
|
|
18
|
+
"prebuild": "npm run lint && npm run clean",
|
|
19
|
+
"build": "npm run build:cjs && npm run build:esm",
|
|
20
|
+
"build:cjs": "tsc -b tsconfig-build-cjs.json",
|
|
21
|
+
"build:esm": "tsc -b tsconfig-build-esm.json",
|
|
22
|
+
"postbuild": "cp README.md package.json ../../LICENSE ../../build/mssql-dialect && cp ../../package.cjs.json ../../build/mssql-dialect/cjs/package.json",
|
|
23
|
+
"lint": "eslint .",
|
|
24
|
+
"test": "jest",
|
|
25
|
+
"cover": "jest --collect-coverage",
|
|
26
|
+
"clean": "npm run clean:src | npm run clean:dist | npm run clean:cover",
|
|
27
|
+
"clean:src": "ts-cleanup -s src --all",
|
|
28
|
+
"clean:dist": "rimraf ../../build/mssql-dialect",
|
|
29
|
+
"clean:cover": "rimraf ../../coverage/mssql-dialect"
|
|
30
|
+
},
|
|
25
31
|
"peerDependencies": {
|
|
26
|
-
"@sqb/builder": "^4.
|
|
32
|
+
"@sqb/builder": "^4.5.0"
|
|
27
33
|
},
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
"
|
|
31
|
-
|
|
34
|
+
"type": "module",
|
|
35
|
+
"main": "cjs/index.js",
|
|
36
|
+
"module": "esm/index.js",
|
|
37
|
+
"types": "esm/index.d.ts",
|
|
38
|
+
"exports": {
|
|
39
|
+
".": {
|
|
40
|
+
"require": "./cjs/index.js",
|
|
41
|
+
"default": "./esm/index.js"
|
|
42
|
+
},
|
|
43
|
+
"./cjs": "./cjs/index.js",
|
|
44
|
+
"./esm": "./esm/index.js"
|
|
32
45
|
},
|
|
33
|
-
"
|
|
34
|
-
"
|
|
35
|
-
"
|
|
46
|
+
"engines": {
|
|
47
|
+
"node": ">=16.0",
|
|
48
|
+
"npm": ">=7.0.0"
|
|
36
49
|
},
|
|
37
50
|
"files": [
|
|
51
|
+
"bin/",
|
|
52
|
+
"cjs/",
|
|
53
|
+
"esm/",
|
|
38
54
|
"LICENSE",
|
|
39
|
-
"README"
|
|
40
|
-
"dist/"
|
|
55
|
+
"README.md"
|
|
41
56
|
],
|
|
42
|
-
"
|
|
43
|
-
"
|
|
44
|
-
"
|
|
45
|
-
"
|
|
46
|
-
"
|
|
47
|
-
"
|
|
48
|
-
"
|
|
49
|
-
"
|
|
50
|
-
"
|
|
51
|
-
|
|
52
|
-
}
|
|
57
|
+
"keywords": [
|
|
58
|
+
"sqb",
|
|
59
|
+
"mssql",
|
|
60
|
+
"sql",
|
|
61
|
+
"query",
|
|
62
|
+
"builder",
|
|
63
|
+
"dialect",
|
|
64
|
+
"serializer",
|
|
65
|
+
"database"
|
|
66
|
+
]
|
|
67
|
+
}
|
package/dist/index.js
DELETED