Skip to content

Commit

Permalink
feat: provide support for groupby
Browse files Browse the repository at this point in the history
Signed-off-by: Muhammad Aaqil <aaqilcs102@gmail.com>
  • Loading branch information
aaqilniz committed Dec 28, 2023
1 parent 012c2de commit 37f6f1c
Showing 1 changed file with 29 additions and 1 deletion.
30 changes: 29 additions & 1 deletion lib/sql.js
Original file line number Diff line number Diff line change
Expand Up @@ -1439,7 +1439,25 @@ SQLConnector.prototype.buildSelect = function(model, filter, options) {
}
}

let extraSelect = '';
if (filter.sum) {
extraSelect = `SUM(${filter.sum}) as sumOf${filter.sum}, `;
}
if (filter.count) {
extraSelect += `COUNT(${filter.count}) as countOf${filter.count}, `;
}
if (filter.avg) {
extraSelect += `AVG(${filter.avg}) as avgOf${filter.avg}, `;
}
if (filter.min) {
extraSelect += `MIN(${filter.min}) as minOf${filter.min}, `;
}
if (filter.max) {
extraSelect += `MAX(${filter.max}) as maxOf${filter.max}, `;
}

let selectStmt = new ParameterizedSQL('SELECT ' +
extraSelect +
this.buildColumnNames(model, filter) +
' FROM ' + this.tableEscaped(model));

Expand All @@ -1449,6 +1467,10 @@ SQLConnector.prototype.buildSelect = function(model, filter, options) {
selectStmt.merge(whereStmt);
}

if (filter.groupBy) {
selectStmt.merge(this.buildGroupBy(filter.groupBy));
}

if (filter.order) {
selectStmt.merge(this.buildOrderBy(model, filter.order));
}
Expand Down Expand Up @@ -1510,7 +1532,13 @@ SQLConnector.prototype.all = function find(model, filter, options, cb) {
}

const objs = data.map(function(obj) {
return self.fromRow(model, obj);
const object = self.fromRow(model, obj);
if (obj[`sumOf${filter.sum}`]) { object[`sumOf${filter.sum}`] = obj[`sumOf${filter.sum}`]; }

Check failure on line 1536 in lib/sql.js

View workflow job for this annotation

GitHub Actions / Code Lint

This line has a length of 98. Maximum allowed is 90
if (obj[`countOf${filter.count}`]) { object[`countOf${filter.count}`] = obj[`countOf${filter.count}`]; }

Check failure on line 1537 in lib/sql.js

View workflow job for this annotation

GitHub Actions / Code Lint

This line has a length of 110. Maximum allowed is 90
if (obj[`avgOf${filter.avg}`]) { object[`avgOf${filter.avg}`] = obj[`avgOf${filter.avg}`]; }

Check failure on line 1538 in lib/sql.js

View workflow job for this annotation

GitHub Actions / Code Lint

This line has a length of 98. Maximum allowed is 90
if (obj[`minOf${filter.min}`]) { object[`minOf${filter.min}`] = obj[`minOf${filter.min}`]; }

Check failure on line 1539 in lib/sql.js

View workflow job for this annotation

GitHub Actions / Code Lint

This line has a length of 98. Maximum allowed is 90
if (obj[`maxOf${filter.max}`]) { object[`maxOf${filter.max}`] = obj[`maxOf${filter.max}`]; }

Check failure on line 1540 in lib/sql.js

View workflow job for this annotation

GitHub Actions / Code Lint

This line has a length of 98. Maximum allowed is 90
return object;
});
if (filter && filter.include) {
self.getModelDefinition(model).model.include(
Expand Down

0 comments on commit 37f6f1c

Please sign in to comment.