Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wellwelwel/mysql2-orm
π² An ORM built on MySQL2, designed to be intuitive, productive and focused on essential functionality.
https://github.com/wellwelwel/mysql2-orm
extend extender extends mysql mysql2 nodejs orm
Last synced: 2 months ago
JSON representation
π² An ORM built on MySQL2, designed to be intuitive, productive and focused on essential functionality.
- Host: GitHub
- URL: https://github.com/wellwelwel/mysql2-orm
- Owner: wellwelwel
- License: mit
- Created: 2022-12-14T08:08:19.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-28T15:34:05.000Z (2 months ago)
- Last Synced: 2024-10-28T17:32:15.247Z (2 months ago)
- Topics: extend, extender, extends, mysql, mysql2, nodejs, orm
- Language: TypeScript
- Homepage: https://wellwelwel.github.io/mysql2-orm/
- Size: 2.04 MB
- Stars: 4
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
[mysql2]: https://github.com/sidorares/node-mysql2
[npm-image]: https://img.shields.io/npm/v/mysql2-orm.svg
[npm-url]: https://npmjs.org/package/mysql2-orm
[downloads-image]: https://img.shields.io/npm/dt/mysql2-orm.svg
[downloads-url]: https://npmjs.org/package/mysql2-orm
[ci-url]: https://github.com/wellwelwel/mysql2-orm/actions/workflows/ci.yml?query=branch%3Amain
[ci-image]: https://img.shields.io/github/actions/workflow/status/wellwelwel/mysql2-orm/ci.yml?event=push&style=flat&label=ci&branch=main
[license-url]: https://github.com/wellwelwel/mysql2-orm/blob/main/License
[license-image]: https://img.shields.io/npm/l/mysql2-orm.svg?maxAge=2592000# MySQL2 ORM
An **ORM** built on [**MySQL2**][mysql2], designed to be intuitive, productive and focused on essential functionality.
[![NPM Version][npm-image]][npm-url]
[![NPM Downloads][downloads-image]][downloads-url]
[![GitHub Workflow Status (with event)][ci-image]][ci-url]
[![License][license-image]][license-url]- This project uses **mysql2/promise**, **createPool** and **execute** behind the scenes.
---
π² [**Documentation Website**](https://wellwelwel.github.io/mysql2-orm/docs/)
---
## Table of Contents
- [Why](#why)
- [Documentation](#documentation)
- [Quickstart](#quickstart)
- [Installation](#installation)
- [Import](#import)
- [Connect](#connect)
- [Basic Usage Example](#basic-usage-example)
- [Close the Connection](#close-the-connection)
- [Curiosity](#curiosity)
- [Why a dice?](#why-a-dice)
- [Acknowledgements](#acknowledgements)---
## Why
- An user-friendly ORM for **INSERT**, **SELECT**, **UPDATE**, **DELETE** and **WHERE** clauses.
- Automatic **Prepared Statements** (including **LIMIT** and **OFFSET**).
- You can also simply use **QueryBuilder** to mount your queries and use them in your original [**MySQL2**][mysql2] connection.
- It will smartly detect and release the connection when using `commit` or `rollback` in a transaction.
- It exposes the `execute` and `query` original methods from [**MySQL2**][mysql2] Pool class.
- **Strictly Typed:** No usage of `any`, `as` neither `satisfies` at all.---
## Documentation
See detailed specifications and usage in [**Documentation**](https://wellwelwel.github.io/mysql2-orm/docs/category/documentation) section for queries, advanced concepts and much more.
---
## Quickstart
### Installation
```shell
npm i mysql2-orm
```If you are using TypeScript, you will need to install [@types/node](https://www.npmjs.com/package/@types/node).
```shell
npm i -D @types/node
```---
### Import
```ts
import { MySQL } from 'mysql2-orm';
```---
### Connect
```ts
const pool = new MySQL({
host: '',
user: '',
database: '',
// ...
});
```---
### Basic Usage Example
The following example is based on **TypeScript** and **ES Modules**, but you can also use **JavaScript** and **CommonJS**.
```ts
const user = await pool.select({
table: 'users',
where: OP.eq('id', 16),
limit: 1,
});
```- See all available operators (**OP**) [here](https://wellwelwel.github.io/mysql2-orm/docs/category/operators).
- Due to `limit: 1`, it returns a direct object with the **row** result.
- The result of **getUser** will be a `RowDataPacket` or `false`.> It's equivalent to:
>
> ```ts
> import mysql, { RowDataPacket } from 'mysql2/promise';
>
> const pool = mysql.createPool({
> // ...
> });
>
> const [users] = execute(
> 'SELECT * FROM `users` WHERE `id` = ? LIMIT ?',
> [16, '1']
> );
>
> const user = users?.[0] || false;
> ```---
### Close the Connection
```ts
await pool.end();
```---
## Curiosity
### Why a dice?
While in English dice and data each have their own word, in Brazil, both the dice and "data" are called "**dado**" even though they refer to different things:
| | πΊπΈ English | π§π· Portuguese (BR) |
| --- | ---------- | ------------------ |
| πΎ | data | dado |
| π² | dice | **dado** |---
## Acknowledgements
- [**MySQL2**][mysql2] is maintained by [**@sidorares**](https://github.com/sidorares).
- The operator names **eq**, **ne**, **gt**, **lt**, **gte** and **lte** are inspired by [**Sequelize**](https://sequelize.org/docs/v6/core-concepts/model-querying-basics/#operators).
- [**Contributors**](https://github.com/wellwelwel/mysql2-orm/graphs/contributors).