WooCommerce Custom Product Tables Beta

Today, we’re pleased to announce the beta of our Custom Products Tables plugin that’s designed to improve the performance of WooCommerce stores by adding database tables that are designed for eCommerce.

This builds on the investment we made in 3.0 which introduced Data Stores and CRUD functionality that provides a uniform way of accessing a store’s data regardless of where it is saved.

Why products first? Simply because it’s one of the most complex Data Stores to change, and one which can positively impact stores of all sizes.

The plugin replaces the current WooCommerce product Data Store with one that makes use of brand new, normalised, dedicated product tables.

Performance Improvements

During our tests we set up two identical stores on the same hosting provider with the same theme and WooCommerce settings, the only difference being one was running the Custom Products Table Feature Plugin.

To test the new product tables we needed to easily create a lot of store data – specifically products, orders, and customers. To do that, we created the WooCommerce Smooth Generator – an easy to use development plugin which allows you to generate WooCommerce data to test the scalibilty of any of your development.

For the tests, we created one data set of 500 products and imported that into two identical stores with Storefront as the theme and no other plugins – one store with the normal WooCommerce data structures and the other with our new feature plugin.

Both stores also had 70,000 orders in the database and meta data in the range of 1.4 million rows.

Average Load times

The results, so far, have been great – with improvements of up to 30% on page load times! Checkout, arguably the most important part of the store experience, has seen the biggest performance gains.

Installing the plugin

To install the plugin you will need :

During the beta period we’ve limited access to the plugin’s functionality so that we can gather feedback from our developer community.

We do not recommend that you install and use this on a live store.

Data Migration

There are two WP-CLI commands available at present to migrate your data:
* wp wc-product-tables migrate-data [--clean-old-data] – This command will migrate data from the current WordPress tables to the new tables, passing the –clean-old-data flag will result in the old data being removed from the WordPress tables. Please be cautious when using this flag as it can result in you loosing your product data if not backed up and you need to revert.
* wp wc-product-tables recreate-tables – This command will drop all the new product tables, removing all data within them and then create new clean tables. This command is useful for testing the migration process from fresh again should you wish. Again, please be cautious as if you ran the migrate-data command with the –clean-old-data flag, running this will result in all your data being lost, so always keep a backup on hand of your products.

Do note that any new products created after you have enabled the plugin will be created in the new tables and will not be available if you disable the plugin again.

What tables are added

  • wc_products – Contains product data eliminating the majority of meta data table storage. A few fields in the meta data table not accessed often, and all extension specific data, will stay in meta data.
  • wc_product_attributes – Contains product attributes and their settings.
  • wc_product_attribute_values – Contains product attribute values and their settings.
  • wc_product_downloads – Contains product downloads and their settings.
  • wc_product_relationships – Contains all product relationships to other products or objects within the WooCommerce ecosystem, i.e. other products, images etc.
  • wc_product_variation_attribute_values – Contains variation data for products.

These tables currently cover all aspects of products, including product settings, attributes, variations, downloads, as well as other relationships such as up-sells, cross-sells, grouped products, and images.

Compatibility with extensions and themes

We’ve kept backwards compatibility in mind by adding specific functionality that checks meta data calls and then intervenes to ensure the data gets routed to and from the correct tables.

Whilst we have taken a care in ensuring developers that are not using CRUD can get/set data in the correct tables, we do advise developers with plugins and themes that make direct meta calls to avoid that and rather use the getter and setter methods provided by the Data Stores since version 3.0. We’ve published documentation here to help you move to the CRUD system.

Release Schedule

Our next milestone is to get this plugin released on WordPress.org so that any store can benefit from the performance improvements. To get there, we need your help putting the beta through its paces so we can catch all issues and better understand the performance improvements and problems you’re seeing in the wild.

Once you’ve installed the beta, please open an issue for any problems you encounter on the GitHub repository. And, let us know in the comments what performance improvements you’re seeing – we’d love to hear from you!

We plan to include the new product tables in a major version update early next year.


19 responses to “WooCommerce Custom Product Tables Beta”

  1. This is awesome! Finally some will deal with this issue.

  2. Phil C Avatar

    ๐ŸŽ‰๐ŸŽ‰๐ŸŽ‰๐ŸŽ‰๐ŸŽ‰๐ŸŽ‰๐ŸŽ‰

  3. mihdan Avatar

    When the image of the goods will move to custom table?

    1. Gerhard Potgieter Avatar
      Gerhard Potgieter

      Images are stored in the new tables, or are you referring to storing the actual image in the db? We have no plans for that yet, only storing the image ids in the new tables atm.

      1. mihdan Avatar

        Ok. Thx

  4. Great when will this be final?
    Woocommerce need performance boost like Prestashop.

    1. Gerhard Potgieter Avatar
      Gerhard Potgieter

      As per the post:

      We plan to include the new product tables in a major version update early next year.

  5. jbfluro Avatar

    This is a fantastic direction, and I’m hoping the same thing is doable with orders.

    I use staging sites extensively and it’s always been very tricky to roll out changes to a live store when there are new orders in the database. Hopefully soon it will just be a case of excluding the WooCommerce tables from the migration.

  6. Julian Weiland Avatar
    Julian Weiland

    Will custom taxonomies continue to work?

    1. Yes, taxonomies are not moving to custom tables.

  7. spark3000 Avatar
    spark3000

    This is great. Plans for Orders too? These guys are trying: https://github.com/liquidweb/woocommerce-custom-orders-table

    1. Look like I am finally going to have to learn how to Github! cheers

  8. It seems like there is some conversion as to the need for some of the basic ideas / functionality behind your plugin. The comments, too, indicate common needs. Best of luck with your plug-in. I have finally decided (after being a woo-commerce end user) to start working on something related, but not quite the same. cheers.

  9. Best of luck with your plug-in. I have finally decided (after being a woo-commerce end user) to start working on something related, but not quite the same. cheers.

  10. is this working now?

  11. Any news on this?

    1. Gerhard Potgieter Avatar
      Gerhard Potgieter

      Hi, Custom Product Tables has not been merged into the WooCommerce core yet. It is still being used as a feature plugin for testing and refining. While progress has been made in developing these tables for better performance, full integration into WooCommerce core is pending, ensuring it maintains compatibility and stability.

      1. Tommaso Avatar

        Hey Gerhard,
        I opened the GitHub repository linked in the article, but the last update dates back to three years ago.
        Is it currently in development? Or has it been abandoned?

  12. I really want use it for my web-site on Woocommerce

Leave a Reply

Your email address will not be published. Required fields are marked *