npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@krishnapawar/mysql-models-builder

v1.5.1

Published

`mysql-models-builder` is a lightweight, easy-to-use, and promise-based Node.js ORM tool designed for MySQL. It simplifies database interactions by offering features like model-based query building, CRUD operations, and support for advanced queries such a

Downloads

186

Readme

mysql-models-builder

The mysql-models-builder is a mysql query builder light weight library that simplifies interactions with MySQL databases and it's promise-based Node.js ORM tool. It streamlines tasks such as creating, inserting, updating, and deleting records, and handles complex operations like joins, pagination, and conditionals. Its intuitive and efficient approach can greatly expedite development, saving both time and effort.


Installation And Import it into your project

npm i mysql-models-builder
const { BaseModels } = require("mysql-models-builder");

OR

npm i @krishnapawar/kp-mysql-models
const { BaseModels } = require("@krishnapawar/kp-mysql-models");

Features

  • Intuitive CRUD operations: Create, Read, Update, and Delete.
  • Advanced relationship handling: hasOne, belongsTo, hasMany.
  • Built-in soft delete functionality.
  • Dynamic pagination and filtering.
  • Simplified advanced joins.
  • Comprehensive helper methods for efficiency.

Setting Up

MySQL Connection

Ensure you have a MySQL connection set up using the mysql library:

const mysql = require("mysql");
const pool = mysql.createPool({
  connectionLimit: 10,
  host: "localhost",
  user: "root",
  password: "",
  database: "test",
});

Basic Model Setup

Create a model for the users table:

const { BaseModels } = require("@krishnapawar/kp-mysql-models");

const User = new BaseModels({
  _table: "users",
  _connection: pool,
});

Defining Models

Create model classes by extending BaseModels for better organization and customization:

Example Steps 1

1 Define the User Class: Extend BaseModels to create a model for the users table. 2 Initialize Connection: Use the super() method to pass the database connection (e.g., pool) to the BaseModels class. 3 Export the Model: Export User to make it accessible across the project.

// suppose tabet name is uses than create file User.js write code like this and use it in controller 
const { BaseModels } = require("@krishnapawar/kp-mysql-models");
const { pool } = require("./db");  // Import the pool connection

class User extends BaseModels {
    constructor() {
        super(pool);  // Connect to the database using super()
    }
}

module.exports = User;

// This code snippet imports necessary modules, defines the User class that extends BaseModels, and connects to the database using the super() method, following the given guidelines.

Example Steps 2

const { BaseModels } = require("@krishnapawar/kp-mysql-models");

class User extends BaseModels {
  constructor() {
    super(pool);
    this._table = "users";
  }
}

module.exports = User;

Example Steps 3

We can customize other model settings such as soft delete, hidden fields, and fields to show. Here's how you can implement this:

const { BaseModels } = require("@krishnapawar/kp-mysql-models");
const { pool } = require("./db");

class User extends BaseModels {
    constructor() {
        super();
        // Manually set the table name and database connection if not automatically connected
        this._table = "users";
        this._connection = pool;

        // Additional model settings
        this._softDelete = false;            // Disable soft delete functionality
        this._hidden = ['password'];         // Fields to hide from query results
        this._show = ['id', 'name', 'email']; // Fields to show in query results
    }
}

module.exports = User;

Note:- This code snippet ensures that the table name (users), the database connection (pool) and other settings are explicitly set within the User class constructor if they are not automatically handled.

Usage Examples

Fetching Data

// Get the first user
const firstUser = await User.first();

// Fetch all users
const users = await User.get();

// Filtered query
const filteredUsers = await User.where({ role: "admin" }).get();

CRUD Operations

// Insert new record
await User.create({ name: "John Doe", email: "[email protected]" });

// Update a record
await User.where({ id: 1 }).update({ name: "John Smith" });

// Delete a record
await User.where({ id: 1 }).delete();

Dynamic Pagination

// Paginate results (10 records per page)
const page = await User.pagination({ currentPage: 2, perPage: 10 }).get();

Soft Deletes

// Soft delete a record
await User.where({ id: 1 }).trashed();

// Restore a soft-deleted record
await User.where({ id: 1 }).restore();

// Fetch only soft-deleted records
const deletedUsers = await User.onlyTrashed().get();

// Fetch only active records
const activedUsers = await User.withoutTrashed().get();

// Soft delete all records
let data = await user.trashedAll();

// Soft restore all records
let data = await user.restoreAll();

// Soft clear trash records
let data = await user.clearTrash();

Let's see more method's Example

// Truncate the table
let data = await User.truncate();

//delete record
let data = await user.deleleAll();

//delete record
let data = await user.destroy({
  where: {
        id: 585,
      }
});

//find first record by id
let data = await User.findOne(13);

The updateOrCreate method updates data if the record exists, or inserts new data if it doesn’t. Specify the fields to update or insert in elements, and conditions in where.

const dataj = await User.updateOrCreate({
      elements: {
        first_name: "ram",
        last_name: "ji",
      },
      where: {
        id: 1223,
      }
    });

The save method can both insert and update records. If a where condition is provided, it updates matching records; otherwise, it creates a new entry.

const dataj = await User.save({
      elements: {
        first_name: "ram",
        last_name: "ji",
      },
      // where: {
      //   id: 1223,
      // },
    });

findOneById()=> Data get by Id you can also use other condition by using obj like {name:"test", date:"12/10/2023"} or simply id

let data = await User.findOneById(13);

Example find() Method

let data = await User.find({
    id:12,
    name:"test", 
    date:"12/10/2023"
  });

Relationships

Database Relations Using with() Method or with key

The with() method in kp mysql model allows you to establish and query relational data within your models, supporting relationships like hasOne, belongsTo, hasMany, and connect. This method lets you fetch related data alongside the main record in a structured way, and you can even build multi-level relationships for nested data retrieval. Note:- belongsTo and hasOne give single response with single object data and other hand hasMany and connect, give array object response with multiple object data `.

The best way you can do same like create ralation in model and than call for example

class User extends BaseModel  {
    constructor() {
        super(pool);
    }

    // Example 1: Define Relationships
    business(){
        return this.hasOne('businesses',{'user_id':'id'});
    }

    // Example 2: Define Relationships
    orders(){
        return this.hasMany('orders',{'business_id':'business_id'},async()=>{
            return {
                where:{
                    order_status:"pending"
                }
            }
        });
    }

    // Example 3: Define Relationships
    order_items(){
        return this.hasMany('order_items',{'order_id':'order_id'},{
            where:{
                status:"pending"
            }
        });
    }

    // Example 4: Define Relationships
    menu_item(){
        return this.belongsTo('menu_items',{'menu_item_id':'menu_item_id'});
    }

    //set all relation method in init
    init(){
        return[
            this.orders(),
            this.business(),
            this.menu_item(),
            this.order_items()
        ]
    }
    
}

export default new User;

Calling in controller

Example 1: Retrieve Related Data

let data = await User.where('id',1).with('business').get();

//output

=>[
    {
        "id": 1,
        "name": "krish",
        "email": "[email protected]",
        "password": "1weqweq",
        "role": "staff",
        "phone": null,
        "created_at": "2024-12-20T19:36:05.000Z",
        "updated_at": "2024-12-20T19:36:05.000Z",
        "business": {
            "business_id": 1,
            "user_id": 1,
            "name": "The Gourmet Kitchen",
            "address": "123 Flavor Street, Food City",
            "phone": "123-456-7890",
            "email": "[email protected]",
            "created_at": "2024-11-01T16:58:28.000Z",
            "updated_at": "2024-12-20T19:37:03.000Z"
        }
    }
]

Example 2: Retrieve Related Data

let data = await User.where('id',1).with('business',{where:{"business_id": 2}}).get();

//output

=>[
    {
        "id": 1,
        "name": "krish",
        "email": "[email protected]",
        "password": "1weqweq",
        "role": "staff",
        "phone": null,
        "created_at": "2024-12-20T19:36:05.000Z",
        "updated_at": "2024-12-20T19:36:05.000Z",
        "business": {}
    }
]

Multi-Level Relationship Example

Retrieve data from multiple nested tables

// example 3
let data = await User.where('id',1).with({
        'business':(q)=>q.setWith({
            "orders":(q)=>q.setWith({
                'order_items':(q)=>q.setWith('menu_item')
                })
        })
    }).get();

// example 4 adding condition in with method
let data = await User.where('id',1).with({
        'business':(q)=>q.setWith({
            "orders":(q)=>q.setWith({
                'order_items':(q)=>q.setWith('menu_item')
                },{
                  where:{
                    "order_id": 1
                    }
                })
        })
    }).get();

// example 5 adding complex raletion in easy way using with method
let data = await User.where('id',1).with({
        'business':(q)=>q.setWith({
            "orders":(q)=>q.setWith({
                'order_items':(q)=>q.setWith('menu_item')
                },{
                  where:{
                    "order_id": 1
                    }
                })
        })
    }).with('menu_item',{where:{id:1}}).get();

Note:- the key same as relation method name that we write in model

Same thing we do and achieve by using config object

const data = await user.first({
      select: [
          "id", 
          "first_name", 
          "last_name"
        ],
      with: {
        doctor: {
          table: "appointments",
          limit: 2,
          select: ["id", "user_id"],
          hasMany: {
            user_id: "id",
          },
        }
      },
      where: {
        id: 585,
      },
    });

Let's See More Examples using with hasOne, belognsTo, hasMany, connect in (with:{}).

const data = await user.get({
      select: ["id", "created_by_id", "first_name", "last_name"],
      with: {
        doctor: {
          table: "appointments",
          limit: 2,
          select: ["id", "user_id"],
          connect: {
            user_id: "id",
          },
        },
        clinic: {
          table: "appointments",
          limit: 2,
          where:{
            role_id="5"
          },
          select: ["id", "user_id"],
          hasMany: {
            doctor_id: "id",
          },
        },
      },
      where: {
        created_by_id: "1",
      },
    }); 

Advanced Joins with dbJoin() Method and dbWith() Method

The dbJoin() method in kp mysql model enables complex joins for enhanced querying. With options like join, innerJoin, leftJoin, and rightJoin, as well as pagination and sorting, it simplifies fetching related data across tables.

let data =  await user
    .select("users.id as uId,appointments.id,users.first_name,lab.first_name as lab_name")
    .join('appointments',"users.id", "appointments.patient_id")
    .innerJoin("users lab","lab.id", "appointments.user_id")
    .leftJoin("users lab1","lab1.id", "appointments.user_id")
    .rightJoin("users lab2","lab2.id", "appointments.user_id")
    .where({
      "users.id": 1122,
    })
    .when(true,(q)=>{
      return q.where("appointments.id",1489);
    })
    .pagination({currentPage:1,perPage:20})
    .latest("appointments.id")
    .dbJoin();

//or we co using config object for example
const data = await user.dbJoin({
      table: "users",
      limit: 10,
      select: [
        "users.id as uId",
        "appointments.id",
        "users.first_name",
        "lab.first_name as lab_name",
      ],
      latest: "appointments.id",
      join: [
        {
          type: "hasOne",
          table: "appointments",
          on: {
            "users.id": "appointments.patient_id",
          },
        },
        {
          type: "belongsTo",
          table: "users lab",
          on: {
            "lab.id": "appointments.user_id",
          },
        },
      ],
      where: {
        "users.id": 1122,
      },
      pagination: page,
    });

you can also use for this method to join mutlipal table

const data = await user.dbWith({
      table: "users",
      limit: 10,
      select: [
        "users.id as uId",
        "appointments.id",
        "users.first_name",
        "lab.first_name as lab_name",
      ],
      latest: "appointments.id",
      with: {
        hasOne: [
          {
            table: "appointments",
            on: {
              "users.id": "appointments.patient_id",
            },
          },
          {
            table: "users clinic",
            on: {
              "clinic.id": "appointments.clinic_id",
            },
          },
        ],
        belongsTo: [
          {
            table: "users lab",
            on: {
              "lab.id": "appointments.user_id",
            },
          },
        ],
      },
      where: {
        "users.id": 1122,
      },
      pagination: page,
    });

Note:- we can use left join, right join, join and inner join instant of hasOne, belognsTo, hasMany, connect in dbJoin(),dbWith() and also with with.

Helper methods

import all Helper method Example

const {
  setDBConnection,
  get,
  first,
  save,
  create,
  update,
  dbJoin,
  dbWith,
} = require("kp-mysql-models");

first you have to setup mysql connection for using helper. we can setup by using setBDConnection() method to connect database or we can directly pass mysql pool or db connection object or params in help method look both example in below.

var mysql = require("mysql");
var pool = mysql.createPool({
  connectionLimit: 10,
  host: "localhost",
  user: "root",
  password: "",
  database: "test",
});

Example 1 for using setDBConnection method

setDBConnection(pool);
const data = await get({
      table: "users",
      whereNotIn: {
        id: [1, 1221],
      }
    });

OR

You can also pass the connection object to each method directly Example 2 for directly pass db connection

const data = await get({
      table: "users",
      whereNotIn: {
        id: [1, 1221],
      }
    },pool);

Available important Helper methods can we use as well

  • setBDConnection,
  • get,
  • first,
  • dbQuery,
  • trunCate,
  • deleleAll,
  • destroy,
  • create,
  • update,
  • save,
  • dbJoin,
  • dbWith,
  • BaseModels
  • collect

Let's see more Exmaples

create method using for create data

const data = await create({
      table: "users",
      elements: {
        first_name: "ram",
        last_name: "ji",
      }
    });

update method using for updating data

const dataj = await update({
      table: "users",
      elements: {
        first_name: "ram",
        last_name: "ji",
      },
      where: {
        id: 1223,
      }
    });

save method using for create or updating data

const dataj = await save({
      table: "users",
      elements: {
        first_name: "ram",
        last_name: "ji",
      },
      // where: {
      //   id: 1223,
      // },
    });

Key Methods

Basic Query Methods

  1. get(): Fetch multiple records.
  2. first(): Fetch the first record.
  3. find(): Retrieve records by conditions.
  4. findOne(): Retrieve single records by conditions.
  5. findOneByEmail(): Fetch a record by its Email.
  6. findOneById(): Fetch a record by its ID.
  7. where(): Apply conditions to filter results.
  8. whereOr(): Apply OR conditions.
  9. whereIn(): Filter records where a column value matches an array.
  10. whereNotIn(): Exclude records where a column value matches an array.
  11. whereNull(): Filter records where a column value is NULL.
  12. whereNotNull(): Filter records where a column value is not NULL.
  13. whereRaw(): Apply raw SQL conditions.
  14. onlyTrashed(): Fetch only soft-deleted records.
  15. exists(): Check if a record exists based on conditions.
  16. pagination(): Implement dynamic pagination.
  17. join(): Add basic join clauses.
  18. leftJoin(): Add left join clauses.
  19. rightJoin(): Add right join clauses.
  20. innerJoin(): Add inner join clauses.

CRUD and Other Methods

  1. create(): Insert new records into the database.
  2. update(): Update existing records.
  3. delete(): Delete records based on conditions.
  4. truncate(): Remove all records from a table.
  5. updateOrCreate(): Update records if they exist or insert them if they don’t.
  6. save(): Create or update records based on conditions.
  7. destroy(): Delete records (supports soft delete).
  8. restore(): Restore soft-deleted records.
  9. trashed(): Soft delete a record.
  10. trashedAll(): Soft delete all records.
  11. restoreAll(): Restore all soft-deleted records.
  12. clearTrash(): delete permanent trashed records.

Relationship Methods

  1. hasOne(): Define a one-to-one relationship.
  2. hasMany(): Define a one-to-many relationship.
  3. belongsTo(): Define an inverse one-to-one or many-to-one relationship.
  4. connect(): Define a custom connection between tables.

Configuration Keywords

| Keyword | Description | |--------------|------------------------------------------| | table | Specifies the database table | | select | Columns to retrieve | | where | Apply conditions | | join | Define table relationships | | onlyTrashed| Fetch only soft-deleted records | | pagination | Define pagination settings | | hasOne | Define a one-to-one relationship | | hasMany | Define a one-to-many relationship | | groupBy | Groups records based on specified columns| | raw | Add raw SQL expressions |


Let's More Query Methods in details

  1. table(x)

    • Specifies the table to query.
    • Example: query.table('users')
  2. select(x)

    • Defines columns to select.
    • Example: query.select(['id', 'name'])
  3. latest(x)

    • Sorts records in descending order by a specified column.
    • Example: query.latest('created_at')
  4. limit(x)

    • Limits the number of records returned.
    • Example: query.limit(10)
  5. groupBy(x)

    • Groups records by specified columns.
    • Example: query.groupBy('status')
  6. raw(x)

    • Adds a raw SQL snippet.
    • Example: query.raw('COUNT(*)')
  7. having(x)

    • Adds a HAVING clause.
    • Example: query.having('COUNT(id) > 10')
  8. onlyTrashed()

    • Adds a condition to return only "trashed" (deleted) records.
    • Example: query.onlyTrashed()

Conditional Querying Methods

  1. when(c, cb)

    • Executes a callback function if a condition is met.
    • Example: query.when(userIsAdmin, q => q.where('role', 'admin'))
  2. where(c, v=false)

    • Adds a WHERE clause with specified conditions.
    • Example: query.where('status', 'active')
  3. whereOr(c, v=false)

    • Adds an OR WHERE clause.
    • Example: query.whereOr('role', 'user')
  4. whereIn(column, values)

    • Filters records where the column’s value is in a specified array.
    • Example: query.whereIn('id', [1, 2, 3])
  5. whereNotIn(column, values)

    • Filters records where the column’s value is not in a specified array.
    • Example: query.whereNotIn('status', ['inactive', 'deleted'])
  6. whereNull(column)

    • Filters records where the column’s value is NULL.
    • Example: query.whereNull('deleted_at')
  7. whereNotNull(column)

    • Filters records where the column’s value is not NULL.
    • Example: query.whereNotNull('created_at')
  8. whereRaw(c)

    • Adds a raw WHERE clause.
    • Example: query.whereRaw('age > 18')

Relationship and Pagination Methods

  1. with(c)

    • Defines relationships to load with the main query (similar to Eloquent's with).
    • Example: query.with({ posts: { ... } })
  2. pagination(x)

    • Configures pagination by setting a currentPage and perPage limit.
    • Example: query.pagination({ currentPage: 1, perPage: 20 })

Join Methods

  1. rightJoin(x, y, z, cb=false)

    • Adds a RIGHT JOIN clause.
    • Example: query.rightJoin('comments', 'users.id', 'comments.user_id')
  2. innerJoin(x, y, z, cb=false)

    • Adds an INNER JOIN clause.
    • Example: query.innerJoin('posts', 'users.id', 'posts.user_id')
  3. join(x, y, z, cb=false)

    • Adds a JOIN clause.
    • Example: query.join('orders', 'users.id', 'orders.user_id')
  4. leftJoin(x, y, z, cb=false)

    • Adds a LEFT JOIN clause.
    • Example: query.leftJoin('profile', 'users.id', 'profile.user_id')

Finalizing the Query

  1. buildQuery(d=false)
    • Finalizes the query structure.
    • Returns the full query object (x) if d is true, or the QueryBuilder instance itself for chaining.

Some Important config Key Words that can help in that methods,


  1. table:

    • Represents the fundamental structure for storing data in a relational database.
  2. select:

    • Used to retrieve specific columns from a table, allowing developers to fetch only the necessary data.
  3. elements:

    • Denotes individual pieces of data within a table, referring to the distinct values or attributes stored.
  4. latest:

    • Facilitates the retrieval of the most recent records from a table based on a specified criterion, often a timestamp.
  5. limit:

    • Restricts the number of records returned in a query, helping manage the quantity of data retrieved.
  6. pagination:

    • A technique for breaking down large result sets into smaller, manageable chunks, commonly used for displaying data in paginated user interfaces .
  7. with:

    • Used in ORM frameworks to specify related data that should be retrieved along with the main query, optimizing data retrieval for relationships.
  8. connect:

    • Establishes connections between tables in an ORM framework, enabling the definition of relationships between entities.
  9. hasOne:

    • Indicates a one-to-one relationship between tables, specifying that one record in the first table is associated with exactly one record in the second table.
  10. belongsTo:

    • Denotes the inverse of a "hasOne" relationship, specifying the table that another table is associated with in a one-to-one relationship.
  11. hasMany:

    • Specifies a one-to-many relationship between tables, where one record in the first table can be associated with multiple records in the second table.
  12. join:

    • Combines data from multiple tables based on specified conditions, allowing for the retrieval of interconnected information.
  13. dbWith:

    • Similar to "with," used in ORM frameworks to specify additional data to be retrieved along with the main query, aiding in optimizing data fetching.
  14. where:

    • Filters data based on specified conditions, allowing developers to narrow down the result set to records that meet certain criteria.
  15. whereOr, whereIn, whereNotIn, whereIs, whereIsNull, whereIsNotNull, whereRaw:

    • Different variations of the "where" clause, providing flexibility in constructing precise queries with various conditions.
  16. on, onOr, onIn, onNotIn, onIs, onRaw:

    • Used in join operations to define conditions under which tables are linked, refining the result set based on specific criteria.
  17. onlyTrashed:

    • Used in the context of soft deletes, indicating that only records marked as deleted should be included in the query results.
  18. groupBy:

  • Groups query results based on specified columns, allowing for data aggregation using aggregate functions like COUNT or SUM.
  1. raw:
  • Enables the inclusion of raw SQL expressions in a query, providing flexibility for complex queries and custom database operations. Exercise caution to prevent SQL injection vulnerabilities.
  1. having:
  • Specifies conditions on aggregated data, similar to the WHERE clause but used for aggregate functions. For example, filtering groups created by GROUP BY.

Here are the descriptions for the provided where and on operations with examples


Where Operations:

  1. where:-

    • Filters records where the 'id' is equal to 1223.
     where: {
             id: 1223,
           }
  2. whereOr:-

    • Filters records where the 'id' is equal to 1223 using the logical OR operator, allowing for multiple conditions.
     whereOr: {
                 id: 1223,
             }
  3. whereIn:-

    • Filters records where the 'id' is either 1 or 1221, allowing for multiple values using the IN clause.
         whereIn: {
                 id: [1, 1221],
             }
  4. whereNotIn:-

    • Filters records where the 'id' is not in the list [1, 1221], excluding records with specified values.
      whereNotIn: {
              id: [1, 1221],
             }
  5. whereIs:-

    • Filters records where the 'last_name' is explicitly set to NULL.
         whereIs: {
             last_name: "NULL",
         }
  6. whereIsNot:-

    • Filters records where the 'last_name' is not set to NULL.
     whereIsNot: {
             last_name: "NULL",
             }
  7. whereRaw:-

    • Allows the use of raw SQL conditions, in this case filtering records where 'name' is 'mohan' and 'age' is 30.
     whereRaw:"name='mohan' and age=30 "

On Operations:

  1. on:-

    • Specifies a condition for joining tables based on the 'id' being equal to 1223.
     on: {
             id: 1223,
             }
  2. onOr:-

    • Specifies a condition for joining tables based on the 'id' being equal to 1223 using the logical OR operator.
     onOr: {
             id: 1223,
             }
  3. onIn:-

    • Specifies a condition for joining tables based on the 'id' being either 1 or 1221, using the IN clause.
     onIn: {
             id: [1, 1221],
             }
  4. onNotIn:-

    • Specifies a condition for joining tables based on the 'id' not being in the list [1, 1221], excluding certain values.
     onNotIn: {
             id: [1, 1221],
             }
  5. onIs:-

    • Specifies a condition for joining tables based on the 'last_name' being explicitly set to NULL.
     onIs: {
         last_name: "NULL",
     }
  6. onIsNot:-

    • Specifies a condition for joining tables based on the 'last_name' not being set to NULL.
     onIsNot: {
             last_name: "NULL",
             }
  7. onRaw:-

    • Allows the use of raw SQL conditions for joining tables, in this case specifying conditions where 'name' is 'mohan' and 'age' is 30.
     onRaw:"name='mohan' and age=30 "

collect Method


const users = [
  { id: 1, name: 'John Doe', age: 30, contact: { address: 'test', phone: 90876543 } },
  { id: 2, name: 'Jane Doe', age: 25, contact: { address: 'test1', phone: 908765431 } },
  { id: 3, name: 'Mary Jane', age: 35, contact: { address: 'test2', phone: 908765432 } },
  { id: 4, name: 'Peter Parker', age: 28 },
  { id: 5, name: 'Bruce Wayne', age: 32 },
];

const collection = collect(users);

console.log(collection.where('name', '=', 'John Doe').where('age', '<', 40).first());
//{ id: 1, name: 'John Doe', age: 30, contact: { address: 'test', phone: 90876543 } }

console.log(collection.whereOr(['name', '=', 'John Doe'], ['age', '<', 30]).toArray());
// [
//   { id: 1, name: 'John Doe', age: 30, contact: { address: 'test', phone: 90876543 } },
//   { id: 2, name: 'Jane Doe', age: 25, contact: { address: 'test1', phone: 908765431 } },
//   { id: 4, name: 'Peter Parker', age: 28 },
// ]

console.log(collection.whereIn('name', ['John Doe', 'Jane Doe']).toArray());
// [
//   { id: 1, name: 'John Doe', age: 30, contact: { address: 'test', phone: 90876543 } },
//   { id: 2, name: 'Jane Doe', age: 25, contact: { address: 'test1', phone: 908765431 } },
// ]

console.log(collection.whereNotIn('name', ['John Doe', 'Jane Doe']).toArray());
// [
//   { id: 3, name: 'Mary Jane', age: 35, contact: { address: 'test2', phone: 908765432 } },
//   { id: 4, name: 'Peter Parker', age: 28 },
//   { id: 5, name: 'Bruce Wayne', age: 32 },
// ]

console.log(collection.whereNull('nickname').toArray());
// [
//   { id: 1, name: 'John Doe', age: 30, contact: { address: 'test', phone: 90876543 } },
//   { id: 2, name: 'Jane Doe', age: 25, contact: { address: 'test1', phone: 908765431 } },
//   { id: 3, name: 'Mary Jane', age: 35, contact: { address: 'test2', phone: 908765432 } },
//   { id: 4, name: 'Peter Parker', age: 28 },
//   { id: 5, name: 'Bruce Wayne', age: 32 },
// ]

console.log(collection.whereNotNull('name').toArray());
// [
//   { id: 1, name: 'John Doe', age: 30, contact: { address: 'test', phone: 90876543 } },
//   { id: 2, name: 'Jane Doe', age: 25, contact: { address: 'test1', phone: 908765431 } },
//   { id: 3, name: 'Mary Jane', age: 35, contact: { address: 'test2', phone: 908765432 } },
//   { id: 4, name: 'Peter Parker', age: 28 },
//   { id: 5, name: 'Bruce Wayne', age: 32 },
// ]

console.log(collection.pluck('contact').toArray());
// [
//   { address: 'test', phone: 90876543 },
//   { address: 'test1', phone: 908765431 },
//   { address: 'test2', phone: 908765432 },
//   undefined,
//   undefined,
// ]


console.log(collection.pluckDeep('contact.phone').toArray()); 
// [90876543, 908765431, 908765432, undefined, undefined]

console.log(collection.where('contact.phone', '>', 908765430).toArray()); 
// [{ id: 2, ...}, { id: 3, ...}]

console.log(collection.whereOr(['contact.phone', '=', 90876543], ['contact.address', '=', 'test1']).toArray()); 
// [{ id: 1, ...}, { id: 2, ...}]

console.log(collection.whereIn('contact.address', ['test', 'test1']).toArray()); 
// [{ id: 1, ...}, { id: 2, ...}]

console.log(collection.whereNotIn('contact.address', ['test', 'test1']).toArray()); 
// [{ id: 3, ...}, { id: 4, ...}, { id: 5, ...}]

console.log(collection.whereNull('contact.phone').toArray()); 
// [{ id: 4, ...}, { id: 5, ...}]

console.log(collection.whereNotNull('contact.phone').toArray()); 
// [{ id: 1, ...}, { id: 2, ...}, { id: 3, ...}]

console.log(collection.pluck('contact.phone').toArray()); 
//[90876543, 908765431, 908765432, null, null]

//you can use in chaining as well example
console.log(collection.where('name', '=', 'John Doe').where('age', '<', 40).first());


// Get the first item
const firstUser = collection.first();
// { id: 1, name: 'John Doe', age: 30 }

// Get the last item
const lastUser = collection.last();
// { id: 5, name: 'Bruce Wayne', age: 32 }

// Check if a value exists in the collection
const containsJohnDoe = collection.contains(users[0]);
// true

// Get unique items
const uniqueAges = collection.pluck('age').unique();
// [30, 25, 35, 28, 32]

// Get the count of items
const count = collection.count();
// 5

// Check if the collection is empty
const isEmpty = collection.isEmpty();
// false

// Convert collection to plain array
const array = collection.toArray();
// same as users

// Chunk the collection into arrays of 2 items each
const chunked = collection.chunk(2); 
// [
//   [{ id: 1, name: 'John Doe', age: 30 }, { id: 2, name: 'Jane Doe', age: 25 }],
//   [{ id: 3, name: 'Mary Jane', age: 35 }, { id: 4, name: 'Peter Parker', age: 28 }],
//   [{ id: 5, name: 'Bruce Wayne', age: 32 }]
// ]

// Order by age in ascending order
const orderedByAgeAsc = collection.orderBy('age');
// [
//   { id: 2, name: 'Jane Doe', age: 25 },
//   { id: 4, name: 'Peter Parker', age: 28 },
//   { id: 1, name: 'John Doe', age: 30 },
//   { id: 5, name: 'Bruce Wayne', age: 32 },
//   { id: 3, name: 'Mary Jane', age: 35 }
// ]

// Order by age in descending order
const orderedByAgeDesc = collection.orderBy('age', 'desc');
// [
//   { id: 3, name: 'Mary Jane', age: 35 },
//   { id: 5, name: 'Bruce Wayne', age: 32 },
//   { id: 1, name: 'John Doe', age: 30 },
//   { id: 4, name: 'Peter Parker', age: 28 },
//   { id: 2, name: 'Jane Doe', age: 25 }
// ]

const totalAge = collection.sum('age'); // 90
const averageAge = collection.avg('age'); // 30
const groupedByAge = collection.groupBy('age');
// {
//   30: [{ id: 1, name: 'John Doe', age: 30 }],
//   25: [{ id: 2, name: 'Jane Doe', age: 25 }],
//   35: [{ id: 3, name: 'Mary Jane', age: 35 }]
// }

//data sort
const sortedByName = collection.sortBy('name')

const phone = collection.values('contact.phone') // [90876543, 908765431, 908765432, undefined, undefined]

const keys = collection.keys().toArray() // ['id', 'name', 'age', 'contact']

// Remove specified keys from the collection
const withoutAge = collect(users).except(['age']).toArray();
// [
//   { id: 1, name: 'John Doe' },
//   { id: 2, name: 'Jane Doe' },
//   { id: 3, name: 'Mary Jane' }
// ]

// Only include specified keys in the collection
const onlyName = collect(users).only(['name']).toArray();
// [
//   { name: 'John Doe' },
//   { name: 'Jane Doe' },
//   { name: 'Mary Jane' }
// ]

// Key the collection by the specified key
const keyedById = collect(users).keyBy('id').toArray();
// {
//   1: { id: 1, name: 'John Doe', age: 30 },
//   2: { id: 2, name: 'Jane Doe', age: 25 },
//   3: { id: 3, name: 'Mary Jane', age: 35 }
// }

// Execute a callback on the collection
const tapped = collect(users).tap(collection => console.log(collection.count())).toArray();
// Logs: 3
// [
//   { id: 1, name: 'John Doe', age: 30 },
//   { id: 2, name: 'Jane Doe', age: 25 },
//   { id: 3, name: 'Mary Jane', age: 35 }
// ]

*Let's see more examples

const items = [1, [2, 3], [[4, 5]], [[[6]]]];
const collection = collect(items);

// Flatten the multi-dimensional array
const flattened = collection.flatten().toArray();
// [1, 2, 3, 4, 5, 6]

// Flatten the array to a depth of 1
const flat1 = collection.flat();
// [1, 2, 3, [4, 5], [[6]]]

// Flatten the array to a depth of 2
const flat2 = collection.flat(2);
// [1, 2, 3, 4, 5, [6]]

// Flatten the array completely
const flatInfinity = collection.flat(Infinity);
// [1, 2, 3, 4, 5, 6]

// Get items that are present in both collections
const intersected = collect([1, 2, 3]).intersect([2, 3, 4]).toArray();
// [2, 3]

// Get items that are in the first collection but not in the second
const diff = collect([1, 2, 3]).diff([2, 3, 4]).toArray();
// [1]


const items = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
const collection = collect(items);

// Paginate the collection with 3 items per page, and get page 2
const paginated = collection.paginate(3, 2);

console.log(paginated);
// {
//   data: Collection { items: [ 4, 5, 6 ] },
//   currentPage: 2,
//   perPage: 3,
//   totalItems: 10,
//   totalPages: 4,
//   from: 4,
//   to: 6
// }

// Get the paginated data
const pageData = paginated.data.toArray();
// [4, 5, 6]

const numbers = [1, 2, 3, 4, 5, 6];
const collection = collect(numbers);

// Iterate over each item and log it
collection.each(item => console.log(item));
// Logs: 1, 2, 3, 4, 5, 6

// Take the first 3 items
const firstThree = collection.take(3).toArray();
// [1, 2, 3]

// Take the last 2 items
const lastTwo = collection.takeLast(2).toArray();
// [5, 6]

// Slice the collection from index 2 to 4
const sliced = collection.slice(2, 4).toArray();
// [3, 4]

// Reverse the collection
const reversed = collection.reverse().toArray();
// [6, 5, 4, 3, 2, 1]

// Splice the collection to remove 2 items from index 2 and add new items
const spliced = collection.splice(2, 2, 'a', 'b').toArray();
// [1, 2, 'a', 'b', 5, 6]

License

MIT

Connect with Me

LinkedIn GitHub Instagram Twitter