<img height="1" width="1" style="display:none" src="https://www.facebook.com/tr?id=490755098261949&amp;ev=PageView&amp;noscript=1">

NEW CASE STUDY: How we built top-rated shopping apps for Crate & Barrel and CB2 :app:

Knex Migration Mastery: Streamlining Schema and Seeds with PostgreSQL

Pratik Agashe
Author Pratik Agashe
Published On Jul 06, 2023
featured_knex_migration

Introduction

Welcome to Heady’s guide on leveraging the power of Knex.js and Knex-migrate in your full-stack web development projects. This blog is one installment of our multipart series, "Building Full-Stack Web Apps with PostGraphile and React.” If you're looking to streamline the way you handle database schema creation and management, you're in the right place. 

Knex.js is a versatile SQL query builder compatible with Postgres, MSSQL, MySQL, MariaDB, SQLite3, Oracle, and Amazon Redshift. It's not only flexible and portable, but it's also an enjoyable tool to use. In this guide, we'll explore how to use Knex.js, along with the complementary tool Knex-migrate, to maintain our database schema and manage dummy data.

Before diving in, ensure you have PostgreSQL running on your machine. Now, let's head out on this journey to simplify your database management tasks and make your development process more efficient.

Getting Started

Let's begin with our schema building using the migration tool. Ensure you have knex and knex-migrate installed in your project. If not, run the following command:

npm install knex knex-migrate

Navigate to theserver folder and execute the following command.

npx knex init.

This command will generate knexfile.js under the server folder. This auto-generated file contains all configurations to connect to the database based on the environment such as development, staging, and production. I have updated the development connection under knexfile.js to connect to our postgres database. Your file should look as follows:

server/src/knexfile.js

 

Here is the .env file for your reference:

 

server/.env

As per this file configuration, we need to create new folders named migrations and seeds under server/db folder. Migrations will consist of files that will determine our schema structure, while seeds will contain files with our dummy or static data to insert into the database.

Now, to use the config connection with knex, we need to create knex.js under src/db. This file will export a connection module based on the environment.

 

server/src/db/knex.js

 

Now, our folder and file structure should look like this:

 

- Server
- db
- migrations
- seeds
knex.js
- src
- index.js
.env
knexfile.js

 

Creating Tables and Inserting Data

In this step, we'll create tables in our database using the migration tool and insert our dummy data into the same. For more details about knex schema, check out: http://knexjs.org/#Schema

To create schema migration, we need to run a command that will generate an auto-created file under the migration folder with a date-time stamp included in the file name.

For example: 20200122192011_migration_create_table.js

Here’s the command to create a migration file:

knex migrate:make migration_create_table

 

server/db/migrations/20200122192011_migration_create_table.js

Now, we need to update this schema to our Postgres database. We’ll run the following command:

npx knex migrate:latest

Now, we can visit our Postgres database and we’ll see that the migration tool has created tables according to the schema we configured.

1_PNq4Um7E-dTeaj4-ghkvGQ
As you see tables created via knex-migrate. (This screenshot is from pgAdmin 4)

Now that we have our tables ready, we can insert some data using seeds. We will create two seed files: one for the user and one for post. Here are the commands and sample files I have created for seeds:

npx knex seed:make 01_users

npx knex seed:make 02_posts

Unlike migration, these commands will create autogenerated files under seeds.
For example: 01_users.js and 02_posts.js

One important thing to remember while creating seed files is to have the filename start with an incremental number, for chronology (you can read more about this here).

Here are the sample seed files I have created to insert users and one blog associated with that user:

server/db/seeds/01_users.js
server/db/seeds/02_posts.js

Here, I am using .del() function to delete all existing entries. You can remove that and update the file, based on your requirement.

Now, let’s run the following command to run seeds files:

npx knex seed:run

ins12_2image2X
Result: server/db/seeds/01_users.js

1_8rDu1O8jufUK21CX-0jmFw
Result: server/db/seeds/02_posts.js

By now, you should have a good grasp of how to use the migration tool and the SQL query builder. You've seen how they can automate the process of creating and maintaining database schemas and managing static data. This is a powerful combination that can greatly simplify your full-stack web development work.

Remember, the power of these tools comes from their flexibility and portability. They allow you to clone your project in a fresh environment and run migration scripts, taking care of everything related to your database schema and static data.

Hopefully this guide has given you a solid foundation to start using these tools in your own projects. Keep exploring and happy coding!

Further Reading

For those of you who want to dive deeper into these topics, I recommend the following resources:

SQL Query Builder Documentation: The official documentation for Knex.js. It's detailed and well-written, covering everything from installation to advanced features.

Database Migration Tools: A helpful article discussing the concept and benefits of database migration tools.

ins12_1image2X

Interested in hiring engineers?

Book a call and we can walk you through our mobile engineering capabilities.

app-clips_1
app-clips_2

Interested in hiring engineers?

Book a call and we can walk you through our mobile engineering capabilities.

LET'S TALK IT OUT.

Figuring out your next step? We're here for you.

Or drop us a line.

hello@heady.io