Skip to content

Latest commit

 

History

History
108 lines (81 loc) · 2.53 KB

README.md

File metadata and controls

108 lines (81 loc) · 2.53 KB

yahapi-mysql

A wrapper for the Node.js mysql library, providing promises and a set of convenience methods.

connect(...)

Connect establishes a connection pool to the MySQL server and must be called before executing a query or transaction.

For available connection options, see mysql.createPool().

import { connect } from '@yahapi/mysql';

connect({
  connectionLimit: 10,
  host: '127.0.0.1',
  user: 'root',
  password: 'root',
  database: 'my_database',
});

query(...)

Executes a query and automatically releases the connection when done.

import { QueryOptions } from '@yahapi/mysql';

const sql = 'SELECT * FROM users WHERE id = ?';
query(sql, ['1g0fee'])
  .then(result => {
    console.log(result);
  });

transaction(...)

Executes a bunch of queries atomically (all or nothing).

The transaction is committed automatically when all queries succeeded or rolled back if any failed.

Example:

import { transaction } from '@yahapi/mysql';

const queries = [{
  query: 'INSERT INTO users (id, name, created) VALUES (?, ?, ?)',
  params: ['1g0fee', 'hendrix', new Date()],
}, {
  query: 'INSERT INTO emails (user_id, email) VALUES (?, ?)',
  params: ['1g0fee', 'johndoe@example.com'],
}];

transaction(queries)
  .then(results => {
    console.log(results);
  })
  .catch(err => {
    console.err('Error occured, transaction was rolled back', err);
  });

now()

Returns the current timestamp in a MySQL date format ('YYYY-MM-DD HH:mm:ss.SSS').

pickWithPrefix(...) and pickWithoutPrefix(...)

When joining tables often you'll find columns have the same name and only one of them is returned. To prevent this a pattern I've adopted is aliasing all columns of one table with a prefix. pickWithPrefix(...) and pickWithoutPrefix(...) are helpers methods to parse such a result.

While this may be cumbersome, I've preferred it over ORM-style solutions in smaller projects; it keeps you close to the actual SQL and is very straightforward.

Example:

import {
  query,
  pickWithPrefix,
  pickWithoutPrefix,
} from '@yahapi/mysql';

const sql = `
  SELECT a.name AS a_name, b.name
  FROM users a
  INNER JOIN groups g ON a.id = b.user_id
  WHERE a.id = ?`;

/*
Result example:

{
  name: 'John Doe',
  groups: [
    { name: 'Group 1' },
    { name: 'Group 1' },
  ],
}
*/
query(sql, ['1g0fee'])
  .then(rows => {
    return Object.assign(
      pickWithPrefix(rows[0], 'a_'),
      groups: rows.map(pickWithoutPrefix),
    );
  });