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

@janiscommerce/query-builder

v1.3.9

Published

Prepare and execute SELECT, INSERT, UPDATE, REMOVE queries from SQL database.

Downloads

220

Readme

query-builder

Build Status Coverage Status npm version

Prepare and execute SELECT, INSERT, UPDATE, REMOVE queries from SQL database.


Instalation

npm install @janiscommerce/query-builder

Configuration

You must have installed both Knex and SQL driver you will use and tables created.


API

  • new QueryBuilder(knex, models), Query Builder constructor.

    • knex, Knex module with the initial configuration.
    • model Model instance. The Model must have table, field, joins, etc. structure define. See more
  • insert(items) ASYNCHRONOUS, Execute INSERT Query.

    • items - Object to Insert or Array of Objects to Insert.
    • Returns, an array, depends on SQL-Database you will use See More Details.
  • save(items) ASYNCHRONOUS, Execute INSERT Query with Upsert (Updated de duplicate rows, and insert the new ones).

    • items - Object to Insert or Array of Objects to Insert.
    • Returns, object depends on SQL-Database-Druver you will use.
  • update(values, filters) ASYNCHRONOUS, Execute UPDATE Query.

    • values will be updated to.
    • filters (where clause) conditions to filter rows. See Filters.
    • Returns, number of rows updated.
  • remove(filters, joins) ASYNCHRONOUS, Execute REMOVE Query.

    • filters (where clause) conditions to filter rows. See Filters.
    • joins if you need to joins table. See Joins.
    • Returns, object depends on SQL-Database-Druver you will use.
  • get( parametres ) ASYNCHRONOUS, Execute SELECT Query.

    • parametres , type object, Parametres for the query, filters, joins, limits.
    • Returns, array with the rows founds.

Parametres

Field

To select a specific field, use fields as key with the selected fields.

See More

Special Functions

It's posible add special functions in the queries, as a key in parametres object.

See More

Joins

Joins are Automatic.

See More

Filters

To filter by fields, use filters as key.

See More

Order

To order, use order key.

See More

Pagination

To use pagination, use limit and page keys.

See More


Errors

The errors are informed with a QueryBuilderError with the proper message for each error.

The codes are the following:

|Code |Description | |-------|---------------------------| |1 |Invalid Model | |2 |Invalid Knex | |3 |Invalid Fields | |4 |Invalid Select Functions | |5 |Invalid Joins | |6 |Invalid Filters | |7 |Invalid Flags | |8 |Invalid Orders | |9 |Invalid Groups | |10 |Invalid Limits | |11 |Invalid Table | |12 |No Items | |13 |No Values | |14 |Nothing Select |


Usage

If you want an example using MySQL. See Here

const QueryBuilder = require('@janniscommerce/query-builder');

// knex is already with init config
// model is an instance of a Model Class

const queryBuilder = new QueryBuilder(knex, model);

// Insert Items
// item an object with valid fields
// Could be multiple items
await queryBuilder.insert(item);

// Save item which could already exist
await queryBuilder.save(item)

// Update any Items
// values, object whit fields to change
// filters, object with the correct filters
await queryBuilder.update(values, filters);

// Remove any Items
// joins, object with table joins define if it's possible
await queryBuilder.remove(filters);

// Get Items
// Get All
const resultsAll = await queryBuilder.get();

// Get with options
// params, object with the options define
const results = await queryBuilder.get(params);