• Stars
    star
    190
  • Rank 203,739 (Top 5 %)
  • Language
    PHP
  • Created over 5 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

WordPress library for managing database table schema upgrades and data seeding

Delicious Brains WordPress Migrations

A WordPress library for managing database table schema upgrades and data seeding.

Ever had to create a custom table for some plugin or custom code to use? To keep the site updated with the latest version of that table you need to keep track of what version the table is at. This can get overly complex for lots of tables.

This package is inspired by Laravel's database migrations. You create a new migration PHP file, add your schema update code, and optionally include a rollback method to reverse the change.

Simply run wp dbi migrate on the command line using WP CLI and any migrations not already run will be executed.

The great thing about making database schema and data updates with migrations, is that the changes are file-based and therefore can be stored in version control, giving you better control when working across different branches.

Requirements

This package is designed to be used on a WordPress site project, not for a plugin or theme.

It needs to be running PHP 5.3 or higher.

You need to have access to run WP CLI on the server. Typically wp dbi migrate will be run as a last stage build step in your deployment process.

Installation

  • composer require deliciousbrains/wp-migrations
  • Bootstrap the package by adding \DeliciousBrains\WPMigrations\Database\Migrator::instance(); to an mu-plugin.

Migrations

By default, the command will look for migration files in /app/migrations directory alongside the vendor folder. This can be altered with the filter dbi_wp_migrations_path. Other paths can be added using the dbi_wp_migrations_paths filter.

Migration file names should follow the yyyy_mm_dd_classname format, eg. 2020_04_09_AddCustomTable.php

An example migration to create a table would look like:

2020_04_09_AddCustomTable.php

<?php

use DeliciousBrains\WPMigrations\Database\AbstractMigration;

class AddCustomTable extends AbstractMigration {

    public function run() {
        global $wpdb;

        $sql = "
            CREATE TABLE " . $wpdb->prefix . "my_table (
            id bigint(20) NOT NULL auto_increment,
            some_column varchar(50) NOT NULL,
            PRIMARY KEY (id)
            ) {$this->get_collation()};
        ";

        dbDelta( $sql );
    }
	
    public function rollback() {
        global $wpdb;
        $wpdb->query( 'DROP TABLE ' . $wpdb->prefix . 'my_table');
    }
}

We are also using the migrations to deploy development data changes at deployment time. Instead of trying to merge the development database into the production one.

For example, to add a new page:

<?php

use DeliciousBrains\WPMigrations\Database\AbstractMigration;

class AddPricingPage extends AbstractMigration {

    public function run() {
        $pricing_page_id = wp_insert_post( array(
            'post_title'  => 'Pricing',
            'post_status' => 'publish',
            'post_type'   => 'page',
        ) );
        update_post_meta( $pricing_page_id, '_wp_page_template', 'page-pricing.php' );
    }
}

Use

You can run specific migrations using the filename as an argument, eg. wp dbi migrate AddCustomTable.

To rollback all migrations you can run wp dbi migrate --rollback, or just a specific migration wp dbi migrate AddCustomTable --rollback.

To quickly scaffold a new migration you can run wp scaffold migration <name>. For example, wp scaffold migration MyMigration will create a new class named MyMigration in the default migration files directory with the correct filename and all required boilerplate code.

More Repositories

1

wp-background-processing

WordPress background processing class
PHP
1,025
star
2

wordpress-nginx

Nginx server configurations for WordPress
DIGITAL Command Language
542
star
3

wp-migrate-db

WordPress plugin that exports your database, does a find and replace on URLs and file paths, then allows you to save it to your computer.
PHP
341
star
4

wp-amazon-s3-and-cloudfront

Automatically copies media uploads to Amazon S3 for delivery. Optionally configure Amazon CloudFront for even faster delivery.
JavaScript
304
star
5

wp-image-processing-queue

Resize WordPress images in the background
PHP
203
star
6

sqlbuddy

phpMyAdmin alternative with a focus on usability
PHP
188
star
7

wp-queue

Job queues for WordPress
PHP
154
star
8

wp-migrate-db-pro-tweaks

Examples of using WP Migrate DB Pro's filters
PHP
98
star
9

spinupwp-composer-site

A WordPress site setup using Composer that is primed and ready to be hosted using SpinupWP.
PHP
82
star
10

better-search-replace

A simple plugin for updating URLs or other text in a database.
PHP
82
star
11

wp-plugin-build

Shell script we use to create builds of our WordPress plugins.
PHP
68
star
12

serialized-editor

A Vue.js component for editing data that has been serialized in PHP
Vue
55
star
13

wp-amazon-s3-and-cloudfront-tweaks

Examples of using Amazon S3 and CloudFront's filters
PHP
53
star
14

wpfbbotkit

A messenger bot developer framework for WordPress
PHP
51
star
15

wp-migrate-db-anonymization

An addon for WP Migrate DB Pro that anonymizes user data
PHP
46
star
16

wp-dbi-file-uploader

A basic JavaScript file uploader plugin that can upload large files
PHP
45
star
17

wp-amazon-web-services

Houses the Amazon Web Services (AWS) PHP libraries and manages access keys. Required by other AWS plugins.
PHP
42
star
18

wp-phpstorm-code-styles

Delicious Brains WordPress coding styles for PhpStorm
25
star
19

npm-scripts

SCSS
23
star
20

spinupwp-plugin

PHP
20
star
21

wp-auto-login

WordPress library for generating automatic login URLs for users
PHP
16
star
22

wp-post-types

WordPress library for registering, reading and writing custom post types.
PHP
13
star
23

spinupwp-mu-plugin

PHP
13
star
24

wp-offload-ses-lite

WP Offload SES Lite sends all outgoing WordPress emails through Amazon Simple Email Service (SES) instead of the local wp_mail() function.
PHP
13
star
25

wp-filesystem

A wrapper for the WP Filesystem
PHP
11
star
26

wp-db-backup

PHP
11
star
27

wp-post-series

WordPress library for adding a series support to posts
PHP
9
star
28

mergebot-schemas

Contains all the WordPress core, plugin and theme schemas for the Mergebot application.
PHP
9
star
29

wp-testimonials

WordPress must-use plugin for managing testimonials, importing from tweets and displaying them.
PHP
7
star
30

spinupwp-cli

The official command-line tool for SpinupWP.
PHP
6
star
31

wp-post-promoter

WordPress must-use plugin for promoting posts via email and social media.
PHP
6
star
32

spinupwp-php-sdk

The official SpinupWP PHP SDK.
PHP
5
star
33

github-gardener

Gardening of GitHub issues and pull requests
PHP
5
star
34

finance-app-trial-project

PHP
4
star
35

wordpress-ansible

Ansible playbook for provisioning WordPress servers
4
star
36

wp-cli-up

wp-cli-up
PHP
4
star
37

wp-mergebot

PHP
3
star
38

testdriiive

PHP
3
star
39

mergebot-schema-generator

Generate Mergebot schema files for WordPress plugins, themes, or core
PHP
2
star
40

woocommerce-subscriptions-renew-active

Abandoned (see below). Extends WooCommerce Subscriptions plugin to enable manual renewals of active subscriptions
PHP
2
star
41

wp-migrate-db-pro-bugs

Bug tracking for WP Migrate DB Pro beta release
2
star
42

wp-markdown

PHP
1
star
43

gp-login-with-email

GlotPress plugin to allow login with the user's email
PHP
1
star