crud-node
  • ⚡Overview
  • ✨Installation
  • 🧰Schema (soon)
  • ☄️Quick Start
  • Guides
    • 🪄Guides (soon)
  • Adapters
    • 💫Adapters
      • Availability 🆕
      • MySQL
      • MySQLX
      • Mongo (soon)
      • Postgres (soon)
      • Cassandra (soon)
      • Oracle (soon)
      • SqlLite (soon)
      • Couchdb (soon)
  • Reference
    • ⭐API Reference
      • Availability 🆕
      • init
      • toString
      • createDocument
      • createDocumentIfNotExists 🆕
      • deleteDocument
      • deleteAll 🆕
      • updateDocument
      • getDocument
      • getDocuments
      • getDocumentByCriteria 🆕
      • searchDocumentsByCriteria 🆕
      • searchDocuments 🆕
      • groupByDocuments 🆕
      • filterDocumentsByCriteria 🆕
      • filterDocuments 🆕
      • filterDocumentsByIds 🆕
      • fetchAll 🆕
      • findDocument 🆕
      • existsDocument
      • getCount
      • getTotal
      • callStoredProcedure 🆕
  • 📃Changelog
  • 📋Roadmap
Powered by GitBook
On this page
  1. Reference
  2. API Reference

groupByDocuments 🆕

Add GROUP BY clause (set the grouping options of the result set).

Signature

groupByDocuments<T extends string>(session: MySQLSession, groupBy: Group<S, T>): Promise<Array<IDocument<T>>>;
groupByDocuments<T extends string>(session: MySQLXSession, groupBy: Group<S, T>): Promise<Array<IDocument<T>>>;

Example

// employeeRouter.{ts|js}
import { GroupBy } from 'crud-node';

import { employeeController } from './employeeController';
import { EmployeeProps } from './schemas/employee';

const transacted = true;

await db.usingSession(async (session) => {
  const data = await employeeController.groupByDocuments<'fired' | EmployeeProps.createdAt>(
    session,
    GroupBy<EmployeeProps, 'fired' | EmployeeProps.createdAt>()
      .fields(EmployeeProps.createdAt)
      .aggregate(EmployeeProps._id, 'fired', AGG.COUNT)
      .toCriteria(),
  );
  return data;
}, transacted);
// employeeRouter.{ts|js}
import { GroupBy } from 'crud-node';

import { employeeController } from './employeeController';
import { EmployeeProps } from './schemas/employee';

const transacted = true;

await db.usingSession(async (session) => {
  const data = await employeeController.groupByDocuments<'fired' | EmployeeProps.createdAt>(
    session,
    GroupBy<EmployeeProps, 'fired' | EmployeeProps.createdAt>()
      .fields(EmployeeProps.createdAt)
      .aggregate(EmployeeProps._id, 'fired', AGG.COUNT)
      .toCriteria(),
  );
  return data;
}, transacted);
PrevioussearchDocuments 🆕NextfilterDocumentsByCriteria 🆕

Last updated 2 years ago

⭐