@tdi-mc/mysql v0.0.7
Table of Contents
Introduction
This library provides an easy-to-use interface for working with MySQL databases in NestJS applications. It is built on top of the popular sequelize and sequelize-typescript libraries, and provides a set of convenient abstractions for working with these libraries.
Installation
To install this library, use either npm or yarn:
npm install @tdi-mc/mysql
# or
yarn add @tdi-mc/mysqlGetting Started
Configuration
To use this library, you must first provide the necessary configuration. This can be done by creating a config.yml file in your application's root directory, with the following content:
mysql:
  host: localhost
  port: 3306
  user: my_user
  password: my_pass
  database: my_databaseReplace the values with your actual database connection information.
Module
Once you have provided the configuration, you can create a MysqlModule in your NestJS application:
import { CoreModule, Module } from '@tdi-mc/core';
import { MysqlModule } from '@tdi-mc/mysql';
@Module({
  imports: [CoreModule, MysqlModule],
})
export class AppModule {}Service
You can then use the MysqlService to interact with the database:
import { Injectable } from '@tdi-mc/core';
import { MysqlService } from '@tdi-mc/mysql';
@Injectable()
export class UserService {
  constructor(private readonly mysqlService: MysqlService) {}
  async getUsers() {
    const users = await this.mysqlService.getModel(UserSchema).findAll();
    return users;
  }
}Repository
Define a Model
You can define a model using @tdi-mc/mysql (based on interface of sequelize-typescript):
import { Table, Column, Model } from '@tdi-mc/mysql';
@Table
export class UserSchema extends Model<UserSchema> {
  @Column
  name: string;
  @Column
  email: string;
}Define a Repository
You can create a repository for your model by extending the MysqlRepository class and providing the model type as a generic argument:
import { Injectable } from '@nestjs/common';
import { MysqlRepository } from '@tdi-mc/mysql';
import { UserSchema } from './user.model';
@Injectable()
export class UserRepository extends MysqlRepository<UserSchema> {}Using Repository in Service
You can then use the repository in your service:
import { Injectable } from '@nestjs/common';
import { UserRepository } from './user.repository';
@Injectable()
export class UserService {
  constructor(private readonly userRepository: UserRepository) {}
  async getUsers() {
    const users = await this.userRepository.findAll();
    return users;
  }
}Reference
Contributing
Contributions to @tdi-mc/mysql are welcome. If you would like to contribute, please fork the repository, make your changes, and submit a pull request.
Please make sure to update tests as appropriate.