@cubejs-backend/schema-compiler 0.35.81 → 0.36.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.
Files changed (60) hide show
  1. package/dist/src/adapter/BaseMeasure.d.ts +2 -2
  2. package/dist/src/adapter/BaseMeasure.d.ts.map +1 -1
  3. package/dist/src/adapter/BaseMeasure.js.map +1 -1
  4. package/dist/src/adapter/BaseQuery.d.ts +52 -5
  5. package/dist/src/adapter/BaseQuery.d.ts.map +1 -1
  6. package/dist/src/adapter/BaseQuery.js +93 -3
  7. package/dist/src/adapter/BaseQuery.js.map +1 -1
  8. package/dist/src/adapter/BaseTimeDimension.d.ts +4 -1
  9. package/dist/src/adapter/BaseTimeDimension.d.ts.map +1 -1
  10. package/dist/src/adapter/BaseTimeDimension.js +35 -19
  11. package/dist/src/adapter/BaseTimeDimension.js.map +1 -1
  12. package/dist/src/adapter/BigqueryQuery.d.ts +13 -0
  13. package/dist/src/adapter/BigqueryQuery.d.ts.map +1 -1
  14. package/dist/src/adapter/BigqueryQuery.js +91 -4
  15. package/dist/src/adapter/BigqueryQuery.js.map +1 -1
  16. package/dist/src/adapter/ClickHouseQuery.d.ts +15 -5
  17. package/dist/src/adapter/ClickHouseQuery.d.ts.map +1 -1
  18. package/dist/src/adapter/ClickHouseQuery.js +30 -16
  19. package/dist/src/adapter/ClickHouseQuery.js.map +1 -1
  20. package/dist/src/adapter/CubeStoreQuery.d.ts +13 -3
  21. package/dist/src/adapter/CubeStoreQuery.d.ts.map +1 -1
  22. package/dist/src/adapter/CubeStoreQuery.js +75 -3
  23. package/dist/src/adapter/CubeStoreQuery.js.map +1 -1
  24. package/dist/src/adapter/Granularity.d.ts +32 -0
  25. package/dist/src/adapter/Granularity.d.ts.map +1 -0
  26. package/dist/src/adapter/Granularity.js +116 -0
  27. package/dist/src/adapter/Granularity.js.map +1 -0
  28. package/dist/src/adapter/MssqlQuery.d.ts +11 -5
  29. package/dist/src/adapter/MssqlQuery.d.ts.map +1 -1
  30. package/dist/src/adapter/MssqlQuery.js +30 -6
  31. package/dist/src/adapter/MssqlQuery.js.map +1 -1
  32. package/dist/src/adapter/MysqlQuery.d.ts +12 -0
  33. package/dist/src/adapter/MysqlQuery.d.ts.map +1 -1
  34. package/dist/src/adapter/MysqlQuery.js +68 -2
  35. package/dist/src/adapter/MysqlQuery.js.map +1 -1
  36. package/dist/src/adapter/PostgresQuery.d.ts +9 -2
  37. package/dist/src/adapter/PostgresQuery.d.ts.map +1 -1
  38. package/dist/src/adapter/PostgresQuery.js +13 -0
  39. package/dist/src/adapter/PostgresQuery.js.map +1 -1
  40. package/dist/src/adapter/SnowflakeQuery.d.ts +10 -0
  41. package/dist/src/adapter/SnowflakeQuery.d.ts.map +1 -1
  42. package/dist/src/adapter/SnowflakeQuery.js +27 -0
  43. package/dist/src/adapter/SnowflakeQuery.js.map +1 -1
  44. package/dist/src/compiler/CubeSymbols.d.ts.map +1 -1
  45. package/dist/src/compiler/CubeSymbols.js +3 -1
  46. package/dist/src/compiler/CubeSymbols.js.map +1 -1
  47. package/dist/src/compiler/CubeValidator.d.ts.map +1 -1
  48. package/dist/src/compiler/CubeValidator.js +53 -4
  49. package/dist/src/compiler/CubeValidator.js.map +1 -1
  50. package/dist/src/compiler/YamlCompiler.d.ts.map +1 -1
  51. package/dist/src/compiler/YamlCompiler.js +10 -8
  52. package/dist/src/compiler/YamlCompiler.js.map +1 -1
  53. package/dist/src/compiler/transpilers/ValidationTranspiler.d.ts +2 -2
  54. package/dist/src/compiler/transpilers/ValidationTranspiler.d.ts.map +1 -1
  55. package/dist/src/compiler/transpilers/ValidationTranspiler.js +1 -6
  56. package/dist/src/compiler/transpilers/ValidationTranspiler.js.map +1 -1
  57. package/dist/src/compiler/utils.d.ts.map +1 -1
  58. package/dist/src/compiler/utils.js +7 -1
  59. package/dist/src/compiler/utils.js.map +1 -1
  60. package/package.json +7 -7
@@ -5,6 +5,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.CubeStoreQuery = void 0;
7
7
  const moment_timezone_1 = __importDefault(require("moment-timezone"));
8
+ const shared_1 = require("@cubejs-backend/shared");
8
9
  const BaseQuery_1 = require("./BaseQuery");
9
10
  const BaseFilter_1 = require("./BaseFilter");
10
11
  const GRANULARITY_TO_INTERVAL = {
@@ -35,7 +36,7 @@ class CubeStoreQuery extends BaseQuery_1.BaseQuery {
35
36
  return 'to_timestamp(?)';
36
37
  }
37
38
  timeStampCast(value) {
38
- return `CAST(${value} as TIMESTAMP)`; // TODO
39
+ return `CAST(${value} as TIMESTAMP)`;
39
40
  }
40
41
  timestampFormat() {
41
42
  return moment_timezone_1.default.HTML5_FMT.DATETIME_LOCAL_MS;
@@ -44,14 +45,85 @@ class CubeStoreQuery extends BaseQuery_1.BaseQuery {
44
45
  return `to_timestamp(${value})`;
45
46
  }
46
47
  subtractInterval(date, interval) {
47
- return `DATE_SUB(${date}, INTERVAL '${interval}')`;
48
+ return `DATE_SUB(${date}, INTERVAL ${this.formatInterval(interval)})`;
48
49
  }
49
50
  addInterval(date, interval) {
50
- return `DATE_ADD(${date}, INTERVAL '${interval}')`;
51
+ return `DATE_ADD(${date}, INTERVAL ${this.formatInterval(interval)})`;
51
52
  }
52
53
  timeGroupedColumn(granularity, dimension) {
53
54
  return `date_trunc('${GRANULARITY_TO_INTERVAL[granularity]}', ${dimension})`;
54
55
  }
56
+ /**
57
+ * Returns sql for source expression floored to timestamps aligned with
58
+ * intervals relative to origin timestamp point.
59
+ */
60
+ dateBin(interval, source, origin) {
61
+ return `DATE_BIN(INTERVAL ${this.formatInterval(interval)}, ${this.timeStampCast(source)}, ${this.timeStampCast(`'${origin}'`)})`;
62
+ }
63
+ /**
64
+ * The input interval with (possible) plural units, like "2 years", "3 months", "4 weeks", "5 days"...
65
+ * will be converted to CubeStore (DataFusion) dialect.
66
+ */
67
+ formatInterval(interval) {
68
+ const intervalParsed = (0, shared_1.parseSqlInterval)(interval);
69
+ const intKeys = Object.keys(intervalParsed).length;
70
+ if (intervalParsed.year && intKeys === 1) {
71
+ return `'${intervalParsed.year} YEAR'`;
72
+ }
73
+ else if (intervalParsed.year && intervalParsed.month && intKeys === 2) {
74
+ return `'${intervalParsed.year} YEAR ${intervalParsed.month} MONTH'`;
75
+ }
76
+ else if (intervalParsed.year && intervalParsed.month && intervalParsed.quarter && intKeys === 3) {
77
+ return `'${intervalParsed.year} YEAR ${intervalParsed.quarter} QUARTER ${intervalParsed.month} MONTH'`;
78
+ }
79
+ else if (intervalParsed.quarter && intKeys === 1) {
80
+ return `'${intervalParsed.quarter} QUARTER'`;
81
+ }
82
+ else if (intervalParsed.quarter && intervalParsed.month && intKeys === 2) {
83
+ return `'${intervalParsed.quarter} QUARTER ${intervalParsed.month} MONTH'`;
84
+ }
85
+ else if (intervalParsed.month && intKeys === 1) {
86
+ return `'${intervalParsed.month} MONTH'`;
87
+ }
88
+ else if (intervalParsed.week && intKeys === 1) {
89
+ return `'${intervalParsed.week} WEEK'`;
90
+ }
91
+ else if (intervalParsed.week && intervalParsed.day && intKeys === 2) {
92
+ return `'${intervalParsed.week} WEEK ${intervalParsed.day} DAY'`;
93
+ }
94
+ else if (intervalParsed.week && intervalParsed.day && intervalParsed.hour && intKeys === 3) {
95
+ return `'${intervalParsed.week} WEEK ${intervalParsed.day} DAY ${intervalParsed.hour} HOUR'`;
96
+ }
97
+ else if (intervalParsed.week && intervalParsed.day && intervalParsed.hour && intervalParsed.minute && intKeys === 4) {
98
+ return `'${intervalParsed.week} WEEK ${intervalParsed.day} DAY ${intervalParsed.hour} HOUR ${intervalParsed.minute} MINUTE'`;
99
+ }
100
+ else if (intervalParsed.week && intervalParsed.day && intervalParsed.hour && intervalParsed.minute && intervalParsed.second && intKeys === 5) {
101
+ return `'${intervalParsed.week} WEEK ${intervalParsed.day} DAY ${intervalParsed.hour} HOUR ${intervalParsed.minute} MINUTE ${intervalParsed.second} SECOND'`;
102
+ }
103
+ else if (intervalParsed.day && intKeys === 1) {
104
+ return `'${intervalParsed.day} DAY'`;
105
+ }
106
+ else if (intervalParsed.day && intervalParsed.hour && intKeys === 2) {
107
+ return `'${intervalParsed.day} DAY ${intervalParsed.hour} HOUR'`;
108
+ }
109
+ else if (intervalParsed.day && intervalParsed.hour && intervalParsed.minute && intKeys === 3) {
110
+ return `'${intervalParsed.day} DAY ${intervalParsed.hour} HOUR ${intervalParsed.minute} MINUTE'`;
111
+ }
112
+ else if (intervalParsed.day && intervalParsed.hour && intervalParsed.minute && intervalParsed.second && intKeys === 4) {
113
+ return `'${intervalParsed.day} DAY ${intervalParsed.hour} HOUR ${intervalParsed.minute} MINUTE ${intervalParsed.second} SECOND'`;
114
+ }
115
+ else if (intervalParsed.hour && intervalParsed.minute && intKeys === 2) {
116
+ return `'${intervalParsed.hour} HOUR ${intervalParsed.minute} MINUTE'`;
117
+ }
118
+ else if (intervalParsed.hour && intervalParsed.minute && intervalParsed.second && intKeys === 3) {
119
+ return `'${intervalParsed.hour} HOUR ${intervalParsed.minute} MINUTE ${intervalParsed.second} SECOND'`;
120
+ }
121
+ else if (intervalParsed.minute && intervalParsed.second && intKeys === 2) {
122
+ return `'${intervalParsed.minute} MINUTE ${intervalParsed.second} SECOND'`;
123
+ }
124
+ // No need to support microseconds.
125
+ throw new Error(`Cannot transform interval expression "${interval}" to CubeStore dialect`);
126
+ }
55
127
  escapeColumnName(name) {
56
128
  return `\`${name}\``;
57
129
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CubeStoreQuery.js","sourceRoot":"","sources":["../../../src/adapter/CubeStoreQuery.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"CubeStoreQuery.js","sourceRoot":"","sources":["../../../src/adapter/CubeStoreQuery.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,32 @@
1
+ import moment from 'moment-timezone';
2
+ import { QueryDateRange, TimeSeriesOptions } from '@cubejs-backend/shared';
3
+ import { BaseQuery } from './BaseQuery';
4
+ export declare class Granularity {
5
+ private readonly query;
6
+ readonly granularity: string;
7
+ readonly granularityInterval: string;
8
+ readonly granularityOffset: string | undefined;
9
+ readonly origin: moment.Moment;
10
+ private readonly predefinedGranularity;
11
+ constructor(query: BaseQuery, timeDimension: any);
12
+ originFormatted(): string;
13
+ minGranularity(): string;
14
+ timeSeriesForInterval(dateRange: QueryDateRange, options?: TimeSeriesOptions): QueryDateRange[];
15
+ resolvedGranularity(): string;
16
+ /**
17
+ * Returns the smallest granularity for the granularityInterval
18
+ */
19
+ granularityFromInterval(): string;
20
+ /**
21
+ * Returns the smallest granularity for the granularityOffset
22
+ */
23
+ granularityFromOffset(): string;
24
+ /**
25
+ * Returns the smallest granularity for the provided interval string
26
+ * Interval may be presented as `1 year 2 months 3 weeks 4 days 5 hours 6 minutes 7 seconds
27
+ * It is important to bubble up from the smallest, as this is used e.g. for minimum rollup granularity
28
+ */
29
+ private granularityFromIntervalString;
30
+ isNaturalAligned(): boolean;
31
+ }
32
+ //# sourceMappingURL=Granularity.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Granularity.d.ts","sourceRoot":"","sources":["../../../src/adapter/Granularity.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,iBAAiB,CAAC;AACrC,OAAO,EAGL,cAAc,EAEd,iBAAiB,EAClB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,qBAAa,WAAW;IAYpB,OAAO,CAAC,QAAQ,CAAC,KAAK;IAXxB,SAAgB,WAAW,EAAE,MAAM,CAAC;IAEpC,SAAgB,mBAAmB,EAAE,MAAM,CAAC;IAE5C,SAAgB,iBAAiB,EAAE,MAAM,GAAG,SAAS,CAAC;IAEtD,SAAgB,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC;IAEtC,OAAO,CAAC,QAAQ,CAAC,qBAAqB,CAAU;gBAG7B,KAAK,EAAE,SAAS,EACjC,aAAa,EAAE,GAAG;IA+Bb,eAAe,IAAI,MAAM;IAIzB,cAAc,IAAI,MAAM;IAsBxB,qBAAqB,CAAC,SAAS,EAAE,cAAc,EAAE,OAAO,GAAE,iBAA6C,GAAG,cAAc,EAAE;IAQ1H,mBAAmB,IAAI,MAAM;IAQpC;;OAEG;IACI,uBAAuB,IAAI,MAAM;IAIxC;;OAEG;IACI,qBAAqB,IAAI,MAAM;IAItC;;;;OAIG;IACH,OAAO,CAAC,6BAA6B;IA2B9B,gBAAgB,IAAI,OAAO;CAKnC"}
@@ -0,0 +1,116 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Granularity = void 0;
7
+ const moment_timezone_1 = __importDefault(require("moment-timezone"));
8
+ const shared_1 = require("@cubejs-backend/shared");
9
+ class Granularity {
10
+ constructor(query, timeDimension) {
11
+ this.query = query;
12
+ this.granularity = timeDimension.granularity;
13
+ this.predefinedGranularity = (0, shared_1.isPredefinedGranularity)(this.granularity);
14
+ this.origin = (0, moment_timezone_1.default)().startOf('year'); // Defaults to current year start
15
+ if (this.predefinedGranularity) {
16
+ this.granularityInterval = `1 ${this.granularity}`;
17
+ }
18
+ else {
19
+ const customGranularity = this.query.cacheValue(['customGranularity', timeDimension.dimension, this.granularity], () => query.cubeEvaluator
20
+ .byPath('dimensions', timeDimension.dimension)
21
+ .granularities?.[this.granularity]);
22
+ if (!customGranularity) {
23
+ throw new Error(`Granularity "${timeDimension.granularity}" does not exist in dimension ${timeDimension.dimension}`);
24
+ }
25
+ this.granularityInterval = customGranularity.interval;
26
+ if (customGranularity.origin) {
27
+ this.origin = moment_timezone_1.default.tz(customGranularity.origin, 'UTC');
28
+ }
29
+ else if (customGranularity.offset) {
30
+ this.granularityOffset = customGranularity.offset;
31
+ this.origin = (0, shared_1.addInterval)(this.origin, (0, shared_1.parseSqlInterval)(customGranularity.offset));
32
+ }
33
+ }
34
+ }
35
+ originFormatted() {
36
+ return this.origin.format('YYYY-MM-DDTHH:mm:ss.SSS');
37
+ }
38
+ minGranularity() {
39
+ if (this.predefinedGranularity) {
40
+ return this.granularity;
41
+ }
42
+ if (this.origin) {
43
+ return this.query.minGranularity(this.granularityFromInterval(), this.query.granularityFor(this.origin.utc()));
44
+ }
45
+ if (this.granularityOffset) {
46
+ return this.query.minGranularity(this.granularityFromInterval(), this.granularityFromOffset());
47
+ }
48
+ return this.granularityFromInterval();
49
+ }
50
+ timeSeriesForInterval(dateRange, options = { timestampPrecision: 3 }) {
51
+ if (this.predefinedGranularity) {
52
+ return (0, shared_1.timeSeries)(this.granularity, dateRange, options);
53
+ }
54
+ return (0, shared_1.timeSeriesFromCustomInterval)(this.granularityInterval, dateRange, this.origin, options);
55
+ }
56
+ resolvedGranularity() {
57
+ if (this.predefinedGranularity) {
58
+ return this.granularity;
59
+ }
60
+ return this.granularityFromInterval();
61
+ }
62
+ /**
63
+ * Returns the smallest granularity for the granularityInterval
64
+ */
65
+ granularityFromInterval() {
66
+ return this.granularityFromIntervalString(this.granularityInterval);
67
+ }
68
+ /**
69
+ * Returns the smallest granularity for the granularityOffset
70
+ */
71
+ granularityFromOffset() {
72
+ return this.granularityOffset ? this.granularityFromIntervalString(this.granularityOffset) : '';
73
+ }
74
+ /**
75
+ * Returns the smallest granularity for the provided interval string
76
+ * Interval may be presented as `1 year 2 months 3 weeks 4 days 5 hours 6 minutes 7 seconds
77
+ * It is important to bubble up from the smallest, as this is used e.g. for minimum rollup granularity
78
+ */
79
+ granularityFromIntervalString(interval) {
80
+ const intervalParsed = (0, shared_1.parseSqlInterval)(interval);
81
+ const intervalKeys = Object.keys(intervalParsed);
82
+ if (intervalKeys.length === 1) {
83
+ return intervalKeys[0];
84
+ }
85
+ if (intervalParsed.second) {
86
+ return 'second';
87
+ }
88
+ else if (intervalParsed.minute) {
89
+ return 'minute';
90
+ }
91
+ else if (intervalParsed.hour) {
92
+ return 'hour';
93
+ }
94
+ else if (intervalParsed.day) {
95
+ return 'day';
96
+ }
97
+ else if (intervalParsed.week) {
98
+ return 'day';
99
+ }
100
+ else if (intervalParsed.month) {
101
+ return 'month';
102
+ }
103
+ else if (intervalParsed.quarter) { // Only quarter+years possible
104
+ return 'month';
105
+ }
106
+ else /* if (intervalParsed.year) */ {
107
+ return 'year';
108
+ }
109
+ }
110
+ isNaturalAligned() {
111
+ const intParsed = this.granularityInterval.split(' ');
112
+ return !(intParsed.length !== 2 || intParsed[0] !== '1');
113
+ }
114
+ }
115
+ exports.Granularity = Granularity;
116
+ //# sourceMappingURL=Granularity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Granularity.js","sourceRoot":"","sources":["../../../src/adapter/Granularity.ts"],"names":[],"mappings":"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"}
@@ -8,9 +8,15 @@ export declare class MssqlQuery extends BaseQuery {
8
8
  castToString(sql: any): string;
9
9
  concatStringsSql(strings: string[]): string;
10
10
  convertTz(field: any): string;
11
- timeStampCast(value: any): string;
12
- dateTimeCast(value: any): string;
13
- timeGroupedColumn(granularity: any, dimension: any): any;
11
+ timeStampCast(value: string): string;
12
+ dateTimeCast(value: string): string;
13
+ timeGroupedColumn(granularity: string, dimension: string): string;
14
+ /**
15
+ * Returns sql for source expression floored to timestamps aligned with
16
+ * intervals relative to origin timestamp point.
17
+ * The formula operates with seconds diffs so it won't produce human-expected dates aligned with offset date parts.
18
+ */
19
+ dateBin(interval: string, source: string, origin: string): string;
14
20
  newParamAllocator(expressionParams: any): MssqlParamAllocator;
15
21
  groupByDimensionLimit(): string;
16
22
  topLimit(): string;
@@ -35,8 +41,8 @@ export declare class MssqlQuery extends BaseQuery {
35
41
  preAggregationLoadSql(cube: any, preAggregation: any, tableName: any): any[];
36
42
  wrapSegmentForDimensionSelect(sql: any): string;
37
43
  seriesSql(timeDimension: any): string;
38
- subtractInterval(date: any, interval: any): string;
39
- addInterval(date: any, interval: any): string;
44
+ subtractInterval(date: string, interval: string): string;
45
+ addInterval(date: string, interval: string): string;
40
46
  sqlTemplates(): any;
41
47
  }
42
48
  export {};
@@ -1 +1 @@
1
- {"version":3,"file":"MssqlQuery.d.ts","sourceRoot":"","sources":["../../../src/adapter/MssqlQuery.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAmBlD,cAAM,mBAAoB,SAAQ,cAAc;IACvC,gBAAgB,CAAC,UAAU,KAAA;CAGnC;AA0BD,qBAAa,UAAW,SAAQ,SAAS;IAChC,SAAS,CAAC,MAAM,KAAA;IAIhB,YAAY,CAAC,GAAG,KAAA;IAIhB,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE;IAIlC,SAAS,CAAC,KAAK,KAAA;IAIf,aAAa,CAAC,KAAK,KAAA;IAInB,YAAY,CAAC,KAAK,KAAA;IAIlB,iBAAiB,CAAC,WAAW,KAAA,EAAE,SAAS,KAAA;IAIxC,iBAAiB,CAAC,gBAAgB,KAAA;IAKlC,qBAAqB;IAQrB,QAAQ;IAOf;;;;;;OAMG;IACI,aAAa;IAWpB;;;;;OAKG;IACI,8BAA8B;IAK9B,oBAAoB,CAAC,kBAAkB,KAAA,EAAE,aAAa,KAAA,EAAE,SAAS,KAAA,EAAE,oBAAoB,KAAA,EAAE,cAAc,KAAA;IAsBvG,eAAe;IAIf,gBAAgB;IAKhB,qBAAqB,CAAC,IAAI,KAAA,EAAE,cAAc,KAAA,EAAE,SAAS,KAAA;IAKrD,6BAA6B,CAAC,GAAG,KAAA;IAIjC,SAAS,CAAC,aAAa,KAAA;IAOvB,gBAAgB,CAAC,IAAI,KAAA,EAAE,QAAQ,KAAA;IAM/B,WAAW,CAAC,IAAI,KAAA,EAAE,QAAQ,KAAA;IAK1B,YAAY;CAcpB"}
1
+ {"version":3,"file":"MssqlQuery.d.ts","sourceRoot":"","sources":["../../../src/adapter/MssqlQuery.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAmBlD,cAAM,mBAAoB,SAAQ,cAAc;IACvC,gBAAgB,CAAC,UAAU,KAAA;CAGnC;AA0BD,qBAAa,UAAW,SAAQ,SAAS;IAChC,SAAS,CAAC,MAAM,KAAA;IAIhB,YAAY,CAAC,GAAG,KAAA;IAIhB,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE;IAIlC,SAAS,CAAC,KAAK,KAAA;IAIf,aAAa,CAAC,KAAK,EAAE,MAAM;IAI3B,YAAY,CAAC,KAAK,EAAE,MAAM;IAI1B,iBAAiB,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;IAIxE;;;;OAIG;IACI,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM;IAcjE,iBAAiB,CAAC,gBAAgB,KAAA;IAKlC,qBAAqB;IAQrB,QAAQ;IAOf;;;;;;OAMG;IACI,aAAa;IAWpB;;;;;OAKG;IACI,8BAA8B;IAK9B,oBAAoB,CAAC,kBAAkB,KAAA,EAAE,aAAa,KAAA,EAAE,SAAS,KAAA,EAAE,oBAAoB,KAAA,EAAE,cAAc,KAAA;IAsBvG,eAAe;IAIf,gBAAgB;IAKhB,qBAAqB,CAAC,IAAI,KAAA,EAAE,cAAc,KAAA,EAAE,SAAS,KAAA;IAKrD,6BAA6B,CAAC,GAAG,KAAA;IAIjC,SAAS,CAAC,aAAa,KAAA;IAOvB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM;IAWxD,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM;IAWnD,YAAY;CAcpB"}
@@ -65,7 +65,7 @@ class MssqlQuery extends BaseQuery_1.BaseQuery {
65
65
  return `TODATETIMEOFFSET(${field}, '${(0, moment_timezone_1.default)().tz(this.timezone).format('Z')}')`;
66
66
  }
67
67
  timeStampCast(value) {
68
- return `CAST(${value} AS DATETIME2)`; // TODO
68
+ return this.dateTimeCast(value);
69
69
  }
70
70
  dateTimeCast(value) {
71
71
  return `CAST(${value} AS DATETIME2)`;
@@ -73,6 +73,23 @@ class MssqlQuery extends BaseQuery_1.BaseQuery {
73
73
  timeGroupedColumn(granularity, dimension) {
74
74
  return GRANULARITY_TO_INTERVAL[granularity](dimension);
75
75
  }
76
+ /**
77
+ * Returns sql for source expression floored to timestamps aligned with
78
+ * intervals relative to origin timestamp point.
79
+ * The formula operates with seconds diffs so it won't produce human-expected dates aligned with offset date parts.
80
+ */
81
+ dateBin(interval, source, origin) {
82
+ const beginOfTime = this.timeStampCast('DATEFROMPARTS(1970, 1, 1)');
83
+ const timeUnit = this.diffTimeUnitForInterval(interval);
84
+ // Need to explicitly cast one argument of floor to float to trigger correct sign logic
85
+ return `DATEADD(${timeUnit},
86
+ FLOOR(
87
+ CAST(DATEDIFF(${timeUnit}, ${this.timeStampCast(`'${origin}'`)}, ${source}) AS FLOAT) /
88
+ DATEDIFF(${timeUnit}, ${beginOfTime}, ${this.addInterval(beginOfTime, interval)})
89
+ ) * DATEDIFF(${timeUnit}, ${beginOfTime}, ${this.addInterval(beginOfTime, interval)}),
90
+ ${this.timeStampCast(`'${origin}'`)}
91
+ )`;
92
+ }
76
93
  newParamAllocator(expressionParams) {
77
94
  return new MssqlParamAllocator(expressionParams);
78
95
  }
@@ -147,13 +164,20 @@ class MssqlQuery extends BaseQuery_1.BaseQuery {
147
164
  return `SELECT ${this.dateTimeCast('date_from')} date_from, ${this.dateTimeCast('date_to')} date_to FROM (VALUES ${values}) ${this.asSyntaxTable} dates (date_from, date_to)`;
148
165
  }
149
166
  subtractInterval(date, interval) {
150
- const amountInterval = interval.split(' ', 2);
151
- const negativeInterval = (amountInterval[0]) * -1;
152
- return `DATEADD(${amountInterval[1]}, ${negativeInterval}, ${date})`;
167
+ const intervalParsed = (0, shared_1.parseSqlInterval)(interval);
168
+ let res = date;
169
+ for (const [key, value] of Object.entries(intervalParsed)) {
170
+ res = `DATEADD(${key}, ${value * -1}, ${res})`;
171
+ }
172
+ return res;
153
173
  }
154
174
  addInterval(date, interval) {
155
- const amountInterval = interval.split(' ', 2);
156
- return `DATEADD(${amountInterval[1]}, ${amountInterval[0]}, ${date})`;
175
+ const intervalParsed = (0, shared_1.parseSqlInterval)(interval);
176
+ let res = date;
177
+ for (const [key, value] of Object.entries(intervalParsed)) {
178
+ res = `DATEADD(${key}, ${value}, ${res})`;
179
+ }
180
+ return res;
157
181
  }
158
182
  sqlTemplates() {
159
183
  const templates = super.sqlTemplates();
@@ -1 +1 @@
1
- {"version":3,"file":"MssqlQuery.js","sourceRoot":"","sources":["../../../src/adapter/MssqlQuery.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"MssqlQuery.js","sourceRoot":"","sources":["../../../src/adapter/MssqlQuery.ts"],"names":[],"mappings":"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"}
@@ -9,6 +9,18 @@ export declare class MysqlQuery extends BaseQuery {
9
9
  subtractInterval(date: any, interval: any): string;
10
10
  addInterval(date: any, interval: any): string;
11
11
  timeGroupedColumn(granularity: any, dimension: any): string;
12
+ /**
13
+ * Returns sql for source expression floored to timestamps aligned with
14
+ * intervals relative to origin timestamp point.
15
+ */
16
+ dateBin(interval: string, source: string, origin: string): string;
17
+ private isIntervalYM;
18
+ /**
19
+ * The input interval with (possible) plural units, like "2 years", "3 months", "4 weeks", "5 days"...
20
+ * will be converted to MYSQL dialect.
21
+ * @see https://dev.mysql.com/doc/refman/8.4/en/expressions.html#temporal-intervals
22
+ */
23
+ private formatInterval;
12
24
  escapeColumnName(name: any): string;
13
25
  seriesSql(timeDimension: any): string;
14
26
  concatStringsSql(strings: any): string;
@@ -1 +1 @@
1
- {"version":3,"file":"MysqlQuery.d.ts","sourceRoot":"","sources":["../../../src/adapter/MysqlQuery.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAuBxC,qBAAa,UAAW,SAAQ,SAAS;IAChC,SAAS,CAAC,MAAM,KAAA;IAIhB,YAAY,CAAC,GAAG,KAAA;IAIhB,SAAS,CAAC,KAAK,KAAA;IAIf,aAAa,CAAC,KAAK,KAAA;IAInB,eAAe;IAIf,YAAY,CAAC,KAAK,KAAA;IAIlB,gBAAgB,CAAC,IAAI,KAAA,EAAE,QAAQ,KAAA;IAI/B,WAAW,CAAC,IAAI,KAAA,EAAE,QAAQ,KAAA;IAI1B,iBAAiB,CAAC,WAAW,KAAA,EAAE,SAAS,KAAA;IAIxC,gBAAgB,CAAC,IAAI,KAAA;IAIrB,SAAS,CAAC,aAAa,KAAA;IAOvB,gBAAgB,CAAC,OAAO,KAAA;IAIxB,gBAAgB;IAIhB,6BAA6B,CAAC,GAAG,KAAA;IAIjC,uBAAuB,CAAC,IAAI,KAAA,EAAE,kBAAkB,KAAA,EAAE,UAAU,KAAA;IAQ5D,YAAY;CAWpB"}
1
+ {"version":3,"file":"MysqlQuery.d.ts","sourceRoot":"","sources":["../../../src/adapter/MysqlQuery.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAuBxC,qBAAa,UAAW,SAAQ,SAAS;IAChC,SAAS,CAAC,MAAM,KAAA;IAIhB,YAAY,CAAC,GAAG,KAAA;IAIhB,SAAS,CAAC,KAAK,KAAA;IAIf,aAAa,CAAC,KAAK,KAAA;IAInB,eAAe;IAIf,YAAY,CAAC,KAAK,KAAA;IAIlB,gBAAgB,CAAC,IAAI,KAAA,EAAE,QAAQ,KAAA;IAI/B,WAAW,CAAC,IAAI,KAAA,EAAE,QAAQ,KAAA;IAI1B,iBAAiB,CAAC,WAAW,KAAA,EAAE,SAAS,KAAA;IAI/C;;;OAGG;IACI,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM;IAaxE,OAAO,CAAC,YAAY;IAIpB;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAmCf,gBAAgB,CAAC,IAAI,KAAA;IAIrB,SAAS,CAAC,aAAa,KAAA;IAOvB,gBAAgB,CAAC,OAAO,KAAA;IAIxB,gBAAgB;IAIhB,6BAA6B,CAAC,GAAG,KAAA;IAIjC,uBAAuB,CAAC,IAAI,KAAA,EAAE,kBAAkB,KAAA,EAAE,UAAU,KAAA;IAQ5D,YAAY;CAWpB"}
@@ -5,6 +5,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.MysqlQuery = void 0;
7
7
  const moment_timezone_1 = __importDefault(require("moment-timezone"));
8
+ const shared_1 = require("@cubejs-backend/shared");
8
9
  const BaseQuery_1 = require("./BaseQuery");
9
10
  const BaseFilter_1 = require("./BaseFilter");
10
11
  const UserError_1 = require("../compiler/UserError");
@@ -45,14 +46,79 @@ class MysqlQuery extends BaseQuery_1.BaseQuery {
45
46
  return `TIMESTAMP(${value})`;
46
47
  }
47
48
  subtractInterval(date, interval) {
48
- return `DATE_SUB(${date}, INTERVAL ${interval})`;
49
+ return `DATE_SUB(${date}, INTERVAL ${this.formatInterval(interval)})`;
49
50
  }
50
51
  addInterval(date, interval) {
51
- return `DATE_ADD(${date}, INTERVAL ${interval})`;
52
+ return `DATE_ADD(${date}, INTERVAL ${this.formatInterval(interval)})`;
52
53
  }
53
54
  timeGroupedColumn(granularity, dimension) {
54
55
  return `CAST(${GRANULARITY_TO_INTERVAL[granularity](dimension)} AS DATETIME)`;
55
56
  }
57
+ /**
58
+ * Returns sql for source expression floored to timestamps aligned with
59
+ * intervals relative to origin timestamp point.
60
+ */
61
+ dateBin(interval, source, origin) {
62
+ const intervalFormatted = this.formatInterval(interval);
63
+ const timeUnit = this.isIntervalYM(interval) ? 'MONTH' : 'SECOND';
64
+ return `TIMESTAMPADD(${timeUnit},
65
+ FLOOR(
66
+ TIMESTAMPDIFF(${timeUnit}, ${this.timeStampCast(`'${origin}'`)}, ${source}) /
67
+ TIMESTAMPDIFF(${timeUnit}, '1970-01-01 00:00:00', '1970-01-01 00:00:00' + INTERVAL ${intervalFormatted})
68
+ ) * TIMESTAMPDIFF(${timeUnit}, '1970-01-01 00:00:00', '1970-01-01 00:00:00' + INTERVAL ${intervalFormatted}),
69
+ ${this.timeStampCast(`'${origin}'`)}
70
+ )`;
71
+ }
72
+ isIntervalYM(interval) {
73
+ return /(year|month|quarter)/i.test(interval);
74
+ }
75
+ /**
76
+ * The input interval with (possible) plural units, like "2 years", "3 months", "4 weeks", "5 days"...
77
+ * will be converted to MYSQL dialect.
78
+ * @see https://dev.mysql.com/doc/refman/8.4/en/expressions.html#temporal-intervals
79
+ */
80
+ formatInterval(interval) {
81
+ const intervalParsed = (0, shared_1.parseSqlInterval)(interval);
82
+ const intKeys = Object.keys(intervalParsed).length;
83
+ if (intervalParsed.year && intKeys === 1) {
84
+ return `${intervalParsed.year} YEAR`;
85
+ }
86
+ else if (intervalParsed.year && intervalParsed.month && intKeys === 2) {
87
+ return `'${intervalParsed.year}-${intervalParsed.month}' YEAR_MONTH`;
88
+ }
89
+ else if (intervalParsed.quarter && intKeys === 1) {
90
+ return `${intervalParsed.quarter} QUARTER`;
91
+ }
92
+ else if (intervalParsed.month && intKeys === 1) {
93
+ return `${intervalParsed.month} MONTH`;
94
+ }
95
+ else if (intervalParsed.week && intKeys === 1) {
96
+ return `${intervalParsed.week} WEEK`;
97
+ }
98
+ else if (intervalParsed.day && intKeys === 1) {
99
+ return `${intervalParsed.day} DAY`;
100
+ }
101
+ else if (intervalParsed.day && intervalParsed.hour && intKeys === 2) {
102
+ return `'${intervalParsed.day} ${intervalParsed.hour}' DAY_HOUR`;
103
+ }
104
+ else if (intervalParsed.day && intervalParsed.hour && intervalParsed.minute && intKeys === 3) {
105
+ return `'${intervalParsed.day} ${intervalParsed.hour}:${intervalParsed.minute}' DAY_MINUTE`;
106
+ }
107
+ else if (intervalParsed.day && intervalParsed.hour && intervalParsed.minute && intervalParsed.second && intKeys === 4) {
108
+ return `'${intervalParsed.day} ${intervalParsed.hour}:${intervalParsed.minute}:${intervalParsed.second}' DAY_SECOND`;
109
+ }
110
+ else if (intervalParsed.hour && intervalParsed.minute && intKeys === 2) {
111
+ return `'${intervalParsed.hour}:${intervalParsed.minute}' HOUR_MINUTE`;
112
+ }
113
+ else if (intervalParsed.hour && intervalParsed.minute && intervalParsed.second && intKeys === 3) {
114
+ return `'${intervalParsed.hour}:${intervalParsed.minute}:${intervalParsed.second}' HOUR_SECOND`;
115
+ }
116
+ else if (intervalParsed.minute && intervalParsed.second && intKeys === 2) {
117
+ return `'${intervalParsed.minute}:${intervalParsed.second}' MINUTE_SECOND`;
118
+ }
119
+ // No need to support microseconds.
120
+ throw new Error(`Cannot transform interval expression "${interval}" to MySQL dialect`);
121
+ }
56
122
  escapeColumnName(name) {
57
123
  return `\`${name}\``;
58
124
  }
@@ -1 +1 @@
1
- {"version":3,"file":"MysqlQuery.js","sourceRoot":"","sources":["../../../src/adapter/MysqlQuery.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"MysqlQuery.js","sourceRoot":"","sources":["../../../src/adapter/MysqlQuery.ts"],"names":[],"mappings":"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"}
@@ -5,8 +5,15 @@ declare class PostgresParamAllocator extends ParamAllocator {
5
5
  }
6
6
  export declare class PostgresQuery extends BaseQuery {
7
7
  newParamAllocator(expressionParams: any): PostgresParamAllocator;
8
- convertTz(field: any): string;
9
- timeGroupedColumn(granularity: any, dimension: any): string;
8
+ convertTz(field: string): string;
9
+ timeGroupedColumn(granularity: string, dimension: string): string;
10
+ /**
11
+ * Returns sql for source expression floored to timestamps aligned with
12
+ * intervals relative to origin timestamp point.
13
+ * Postgres operates with whole intervals as is without measuring them in plain seconds.
14
+ * This implementation should also work for AWS RedShift.
15
+ */
16
+ dateBin(interval: string, source: string, origin: string): string;
10
17
  hllInit(sql: any): string;
11
18
  hllMerge(sql: any): string;
12
19
  countDistinctApprox(sql: any): string;
@@ -1 +1 @@
1
- {"version":3,"file":"PostgresQuery.d.ts","sourceRoot":"","sources":["../../../src/adapter/PostgresQuery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAalD,cAAM,sBAAuB,SAAQ,cAAc;IAC1C,gBAAgB,CAAC,UAAU,KAAA;CAGnC;AAED,qBAAa,aAAc,SAAQ,SAAS;IACnC,iBAAiB,CAAC,gBAAgB,KAAA;IAIlC,SAAS,CAAC,KAAK,KAAA;IAIf,iBAAiB,CAAC,WAAW,KAAA,EAAE,SAAS,KAAA;IAIxC,OAAO,CAAC,GAAG,KAAA;IAIX,QAAQ,CAAC,GAAG,KAAA;IAIZ,mBAAmB,CAAC,GAAG,KAAA;IAIvB,YAAY;IA2BnB,IAAW,iBAAiB,YAE3B;CACF"}
1
+ {"version":3,"file":"PostgresQuery.d.ts","sourceRoot":"","sources":["../../../src/adapter/PostgresQuery.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAalD,cAAM,sBAAuB,SAAQ,cAAc;IAC1C,gBAAgB,CAAC,UAAU,KAAA;CAGnC;AAED,qBAAa,aAAc,SAAQ,SAAS;IACnC,iBAAiB,CAAC,gBAAgB,KAAA;IAIlC,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAIhC,iBAAiB,CAAC,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;IAIxE;;;;;OAKG;IACI,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM;IAQjE,OAAO,CAAC,GAAG,KAAA;IAIX,QAAQ,CAAC,GAAG,KAAA;IAIZ,mBAAmB,CAAC,GAAG,KAAA;IAIvB,YAAY;IA2BnB,IAAW,iBAAiB,YAE3B;CACF"}