@sqb/mssql-dialect 4.2.1 → 4.5.1

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 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
- constructor() {
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());
@@ -0,0 +1,3 @@
1
+ {
2
+ "type": "commonjs"
3
+ }
File without changes
package/esm/index.js ADDED
@@ -0,0 +1,3 @@
1
+ import { registerSerializer } from '@sqb/builder';
2
+ import { MSSqlSerializer } from './ms-sql-serializer.js';
3
+ registerSerializer(new MSSqlSerializer());
@@ -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.2.1",
4
+ "version": "4.5.1",
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
- "keywords": [
16
- "javascript",
17
- "typescript",
18
- "sql",
19
- "query",
20
- "builder",
21
- "dialect",
22
- "oracle",
23
- "database"
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.2.0"
32
+ "@sqb/builder": "^4.5.0"
27
33
  },
28
- "main": "dist/index.js",
29
- "types": "dist/index.d.ts",
30
- "engines": {
31
- "node": ">= 16.0"
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
- "directories": {
34
- "lib": "dist",
35
- "test": "test"
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
- "scripts": {
43
- "build": "tsc -b tsconfig-build.json",
44
- "prebuild": "npm run lint && npm run clean:dist",
45
- "postbuild": "copyfiles package.json README.md LICENSE ../../build/mssql-dialect",
46
- "clean": "ts-cleanup -s src --all & ts-cleanup -s test",
47
- "clean:dist": "rimraf ../../build/mssql-dialect",
48
- "compile": "tsc",
49
- "lint": "eslint src/** --no-error-on-unmatched-pattern",
50
- "test": "TS_NODE_PROJECT='./test/tsconfig.json' mocha -r ts-node/register -r tsconfig-paths/register --reporter spec test/**/*.spec.ts"
51
- }
57
+ "keywords": [
58
+ "sqb",
59
+ "mssql",
60
+ "sql",
61
+ "query",
62
+ "builder",
63
+ "dialect",
64
+ "serializer",
65
+ "database"
66
+ ]
52
67
  }
package/dist/index.js DELETED
@@ -1,5 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const builder_1 = require("@sqb/builder");
4
- const MSSqlSerializer_1 = require("./MSSqlSerializer");
5
- (0, builder_1.registerSerializer)(new MSSqlSerializer_1.MSSqlSerializer());