This library provides a simple and flexible query builder for generating SQL queries. It supports multiple join types and includes support for INNER, LEFT, RIGHT, CROSS, and NATURAL joins, as well as condition types like ON and USING.
A simple and flexible SQL query builder for constructing SELECT, INSERT, UPDATE, and DELETE queries. It supports joins, conditions, sorting, limits, offsets, and grouping, allowing you to easily build and customize SQL queries in a clean and intuitive manner.
- β Fluent API: Chainable methods for easy query construction.
- β Named Parameters: Prevent SQL injection by binding named parameters.
- β Select Queries: Build flexible SELECT statements with column and table aliasing.
- β Joins: Support for INNER, LEFT, RIGHT, CROSS, and NATURAL joins.
- β Where Conditions: Add WHERE, AND, and OR conditions dynamically.
- β Grouping & Aggregation: GROUP BY, HAVING, and aggregate functions.
- β Sorting & Pagination: ORDER BY, LIMIT, and OFFSET support.
- β Error Handling: Ensures correct query syntax and missing criteria validation.
npm install @ialopezg/db
const query = new QueryBuilder().select("id", "name");
console.log(query.getQuery()); // SELECT id, name FROM table
const query = new QueryBuilder().from("users");
console.log(query.getQuery()); // SELECT * FROM users
const query = new QueryBuilder()
.select("id", "name")
.from("users", "u")
.innerJoin("orders", "o", "on", "u.id = o.user_id");
console.log(query.getQuery());
// SELECT id, name FROM users u INNER JOIN orders o ON u.id = o.user_id
const query = new QueryBuilder()
.select("id", "name")
.from("users")
.where("age > 30")
.andWhere("status = 'active'");
console.log(query.getQuery());
// SELECT id, name FROM users WHERE age > 30 AND status = 'active'
const query = new QueryBuilder()
.select("category", "COUNT(id)")
.from("products")
.groupBy("category")
.having("COUNT(id) > 10");
console.log(query.getQuery());
// SELECT category, COUNT(id) FROM products GROUP BY category HAVING COUNT(id) > 10
const query = new QueryBuilder()
.select("id", "name")
.from("users")
.orderBy("age", "ASC");
console.log(query.getQuery());
// SELECT id, name FROM users ORDER BY age ASC
const query = new QueryBuilder()
.select("id", "name")
.from("users")
.setLimit(10)
.setOffset(20);
console.log(query.getQuery());
// SELECT id, name FROM users LIMIT 10 OFFSET 20
const query = new QueryBuilder()
.select("id", "name")
.from("users")
.where("id = :id")
.setParameter({ name: ":id", value: 10 });
console.log(query.getQuery());
// SELECT id, name FROM users WHERE id = 10
const query = new QueryBuilder()
.select("id", "name")
.from("users")
.where("id = :id")
.andWhere("status = :status")
.setParameters([
{ name: ":id", value: 10 },
{ name: ":status", value: "active" }
]);
console.log(query.getQuery());
// SELECT id, name FROM users WHERE id = 10 AND status = 'active'
Select the columns to retrieve.
If no columns are provided, it defaults to
*
.
Replace any existing
SELECT
columns.
Adds additional columns to the SELECT clause, ensuring no duplicates.
Specify the table or entity to query from. You can pass either a string (table name) or a class (entity). Optionally, you can provide an alias.
innerJoin(entity: string, alias?: string, conditionType?: JoinConditionType, criteria?: string): this
Adds an INNER JOIN
to the query. The condition can be specified with ON
, USING
, or NATURAL
.
leftJoin(entity: string, alias?: string, conditionType?: JoinConditionType, criteria?: string): this
Adds a LEFT JOIN
to the query. The condition can be specified with ON
, USING
, or NATURAL
.
rightJoin(entity: string, alias?: string, conditionType?: JoinConditionType, criteria?: string): this
Adds a RIGHT JOIN
to the query. The condition can be specified with ON
, USING
, or NATURAL
.
Adds a CROSS JOIN
to the query.
Adds a NATURAL JOIN
to the query.
Adds a WHERE
condition to the query.
Replace any existing
WHERE
columns.
Adds an AND
condition to the WHERE clause of the query.
Adds an OR
condition to the WHERE clause of the query.
Define the GROUP BY clause with one or more columns.
Replace any existing
GROUP BY
columns.
Adds additional columns to the GROUP BY clause, ensuring no duplicates.
Adds a HAVING
condition to the query.
Replace any existing
HAVING
columns.
Adds an AND
condition to the HAVING clause of the query.
Adds an OR
condition to the HAVING clause of the query.
Adds an ORDER BY
clause to the query, specifying the column and sort order (ASC
or DESC
).
Adds an additional ORDER BY
clause, avoiding duplicates.
Sets the LIMIT
for the query, restricting the number of rows returned.
Sets the OFFSET
for the query, allowing for pagination.
Generate the SQL query based on the specified conditions.
Set a single named parameter for the query.
query.setParameter({ name: ":id", value: 42 });
Sets multiple named parameters at once.
query.setParameters([
{ name: ":id", value: 10 },
{ name: ":status", value: "active" }
]);
const query = new QueryBuilder()
.select("id", "name")
.from("users", "u")
.innerJoin("orders", "o", "on", "u.id = o.user_id")
.where("u.status = 'active'")
.andWhere("o.date > '2025-01-01'")
.groupBy("u.name")
.orderBy("u.name")
.setLimit(10)
.setOffset(20);
console.log(query.getQuery()); // SELECT id, name FROM users u INNER JOIN orders o ON u.id = o.user_id WHERE u.status = 'active' AND o.date > '2025-01-01' GROUP BY u.name ORDER BY u.name LIMIT 10 OFFSET 20
If a required condition or criteria is missing, the library throws an error.
// Throws error because criteria is missing
queryBuilder
.leftJoin('users', 'u', 'ON', '')
.getQuery(); // Error: INNER JOIN requires a condition criteria when using ON
This project is licensed under the MIT License. See LICENSE for details.