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 🙏

© 2024 – Pkg Stats / Ryan Hefner

vortexql

v1.1.0

Published

An SQL migration tool for Node.JS

Downloads

12

Readme

VortexQL - SQL Migrations the right way

VortexQL has been designed to be the perfect tool when it comes to SQL migrations.

npm version Downloads Lint

Table of contents

  1. Installation
  2. Configuration
  3. Usage
  4. Contributing

Installation

Prerequisites: Node >= 14.21.3

You can install VortexQL using this command:

npm install vortexql

After that, you can use the Command-Line Interface (CLI) using either

  • vortex
  • ./node_modules/bin/vortex

Simply use vortex or vortex help to display the help message, it contains all the available commands.

You can generate a configuration file using the vortex init command.

Configuration

After running vortex init, you'll see a new file in your root directory called vortexconfig.json.

This file will look like this:

{
    "database": {
        "port": 3306,
        "host": "localhost",
        "user": "root",
        "password": "root",
        "database": "main_dev"
    },
    "migrationsLocation": "./migrations",
    "migrationsHistorySavingStrategy": "database"
}

It's pretty straightforward, the database key contains all the database connection information.

migrationsLocation is the directory that will contain the SQL migrations.
migrationsHistorySavingStrategy can either be set to database or filesystem.

If you select the filesystem mode, VortexQL will create a .vortex folder at the root of your project to store locally the history of the migrations. Do not delete this folder and its content, or your migration history will be reset and the next time you run the vortex migrate command, all your migrations will play, even if they were already played.

In another hand, if you select the database mode, VortexQL will create a new table in your database, named migrations_history. This table will store the history of the migrations, do not delete it.

Usage

5 commands are available with the VortexQL CLI.

  • init will initialise VortexQL and create a default configuration file.
  • create will create a new migration. Use --mjs option for '.mjs' file extension.
  • list will display a list & status (played or not played) of all the existing migrations.
  • migrate will execute all the non-played migrations.
  • revert <version> will revert the database to the version passed as the first argument.

The revert command can be used with the --no-interaction to automatically reply with the default option when a confirmation is needed.

The help command is also available and will display the following message:

Usage: vortex [options] [command]

An SQL migration tool for Node.JS

Options:
  -V, --version               output the version number
  -h, --help                  display help for command

Commands:
  migrate                     Migrates the database to the newest migration.
  create [options]            Creates a new migration. [--mjs] option to use '.mjs' file extension.
  revert [options] <version>  Reverts the database to the given migration ID's state
  list                        Shows a list of the migrations (played or not) and their description.
  init                        Creates a default configuration file.
  help [command]              display help for command

Contributing

If you want to contribute to this project, feel free to submit a pull request on the GitHub repository.
Also, if you need to get in touch with me, email me using the one provided in the package.json file.

© Edouard Courty - 2023