Product

Major Feature Release: Schema Evolution

Dec 10, 2023
Written by 
Charles Chretien
Co-Founder
Share

How and why we built schema evolution into the Prequel platform

Category
Product
Time to read
3 min read

As you add features to your application, the shape of data in your database is likely to change. You'll add new columns, and deprecate old ones – it's the circle of life of the db world. If you're syncing data to other places (your customer's data warehouse, for example), those changes need to be propagated there too.

Let's make this concrete: say you offer a payment product, and you have a table called `transactions`. This table records `date`, `amount`, and `merchant`.

Now, folks on your engineering team do a bunch of hard work, and they're able to tag each merchant with a category like food or apparel or airline. This is useful data to keep, so they add a column to the table called `category`. Of course, your customers want to get this category data too.

Why it's hard to build in-house

Propagating those changes to your customer's warehouses is a thorny problem. First, you need to detect that a change has happened on the source side. Then, you need to check the state of existing destinations. And, in relevant cases, you need to propagate the change (ie create the new column) there. You need to be diligent about types while doing: this new column might be of type `text` in Snowflake, `varchar` in Redshift, and `string` in BigQuery.

These steps need to happen before you run any new data transfers: otherwise, the destination will complain that you're trying to insert data into a column that doesn't exist.

And then, assuming you got these basic steps right, you get into some fun edge-cases. What happens if the destination is offline and non-reachable when you try to propagate this schema change? Will syncs be broken moving forward or is your evolution engine capable of recovering gracefully? In that same offline database scenario, what happens if you add two columns in a row? How will you keep track of the last known state of the destination so that you can evolve it appropriately?

Our solution

We've built all this functionality into the Prequel platform, so that you don't have to. Whenever you make a change to your source config file, this change is automatically propagated to all your destinations. If you add columns, we'll add them seamlessly. If you remove columns, we'll flag them as deprecated in the destination. This allows your customers to leverage the new functionality without ever having to deal with a breaking change in their data pipeline. We handle the edge cases mentioned above and a whole host of other ones too.

You can read about the exact functionality here. The feedback we've gotten from customers is that it feels a little bit like magic. To us, that's the best compliment there is. If you'd like to learn more about the feature, or otherwise chat about how we could power your data exports and save you heaps of engineering time and headache, drop us a note.

See how we can help you launch data sharing today.

Thank you! Check your inbox soon for a note from us to schedule a demo.
Woopsie, something went wrong while submitting the form. We'll get right on it. In the meantime, can you please email us at hello@prequel.co instead?