Multi-Environment Tables

I just realized how simple environment specific tables are when using the ENV dependency.

The Demo has a table data for the Published environment and a table data_dev for all other environments.

Create tables

Create tables data and data_dev with the same schema and populate some data in them.

Enable Accelerated Tables for dict like access to tables.

Setup ENV

Create the env table with the following setup:

image
Note that for the data_dev entry, the Published bool is None rather than False. None indicates this as the default value if the current environment can’t be matched to any other entry.

Use ENV

Allow ENV to select the correct table name

from ENV import environ

data_table = app_tables[environ.get('data_table')]

@anvil.server.callable
def get_data():
    return data_table.search()

That’s it.

And we are done. The get_data() function in the Published app will use the data table and all other environments will use the data_dev table.

Demo

Publish a version of the app. Now try running the app in the development environment and hitting the app from your published URL.

Clone

ENV

ENV Clone
Third Party Dependency id: AFKPYPDLJMH2TYVK
github

3 Likes