Learn how to store data in Anvil’s hosted database system
Anvil provides a robust Python-based database system built on top of PostgreSQL.
Follow this quickstart to create a data table in your app’s default database, get your app to store data in it, and read the data back.
Anvil provides a robust Python-based database system built on top of PostgreSQL called Data Tables.
Follow this quickstart to create a database, get your app to store data in it, and read the data back.
Create an app
Log in to Anvil and click ‘New Blank App’. Choose the Material Design theme.
data:image/s3,"s3://crabby-images/67efa/67efaf972a4ef5eb253fd3789e6818488b7da920" alt="Location of the Create App button"
data:image/s3,"s3://crabby-images/4284b/4284b67e3ae4afd914e1d4e071e4f0db151e6b69" alt="Location of the Create App button"
Add the Data Tables Service
In the App Browser, click the + next to Services.
data:image/s3,"s3://crabby-images/48dd6/48dd6c9aaaaa3aa43d847a0949792397e2d2eb49" alt="App Browser showing the plus next to Services"
You’ll see a list of available services and integrations. Click on Data Tables.
data:image/s3,"s3://crabby-images/9aa32/9aa32b5d4ba084caa9cb6cfbc9d2206e33a6d1a4" alt="Services list with Data Tables highlighted"
Create a table
Click ‘Add A Table’ and name it square_numbers
.
data:image/s3,"s3://crabby-images/c0959/c095908747b053ebaa5cf08327435ee6a2aeb9fd" alt="Data Tables Service with Add A Table highlighted"
Navigate to “Data” in the Sidebar Menu and click “+ Add Table”.
data:image/s3,"s3://crabby-images/4b2da/4b2daaf7f12f49c7662582fb246b32d1487370fc" alt="Add Table button highlighted in the Data Service"
Change the name to be square_numbers
.
data:image/s3,"s3://crabby-images/f99e2/f99e22b8e4d85f0dc4d408a30e0e0fba0cd9b2e1" alt="Changing the Python name of the table to be `square_numbers`"
Add columns
Click New Column, and in the menu that pops up, name the new column base_number
. Change the Column Type to “Number”.
data:image/s3,"s3://crabby-images/32283/32283fc47f608ab27451f166d0a6067e3ed6998b" alt="Data Tables Service with Add A Column dropdown open"
data:image/s3,"s3://crabby-images/6146e/6146e1003630a66025027ff9c6c240a4fa52898b" alt="A Data Table with the New Column dropdown open"
Then add another Number column named squared
.
data:image/s3,"s3://crabby-images/412d7/412d75fb9a16881c25a5494f2e2866f298994f1f" alt="Data Tables Service with a table named square_numbers and two Number columns named base_number and squared"
data:image/s3,"s3://crabby-images/78938/789388dc052ad129228dac02e1ac08cfb032511e" alt="A Data Table with two Number columns named base_number and squared"
Make the table client-writable
In the bar above the columns, there are some controls relating to this table.
Use the dropdown menu that says ‘Client code’ to select ‘Client code can search, edit and delete’. This gives our client-side Forms permission to read from and write to this table.
data:image/s3,"s3://crabby-images/0c143/0c143ebec31170149cf3203501057b5afd9a1888" alt="Data Tables Service with Add A Column dropdown open"
data:image/s3,"s3://crabby-images/7741c/7741c6cb4ca19dc52cca44822bbc3bf17a544fe9" alt="A Data Table with Add A Column dropdown open"
Write to the database from Python code
Under Forms in the App Browser, select Form1.
data:image/s3,"s3://crabby-images/6bee8/6bee8150d6ced066f27d7d5b356814827dfe8344" alt="App Browser showing where to find Form1"
data:image/s3,"s3://crabby-images/538ba/538ba2c2a5f31bfcb1df71210ac356d218c5673a" alt="App Browser showing where to find Form1"
Click on the ‘Code’ tab to see the Python code for Form1
.
data:image/s3,"s3://crabby-images/1d20d/1d20dd63cf9c05ab79990ee51d89d69cb7786c5d" alt="The Design View for Form1 with the Code tab in the top-right highlighted"
data:image/s3,"s3://crabby-images/d5ad0/d5ad04be546701fc357bc74e21f94abac58c683a" alt="The Design View for Form1 with the Code tab in the top-right highlighted"
You will see a few lines of pre-written code. Your Form is represented as a class called Form1. It currently has
only one method, the __init__
method.
data:image/s3,"s3://crabby-images/1edb1/1edb15d488b4b7968a0045cb17da3e7177ce814e" alt="The Code View for Form1"
data:image/s3,"s3://crabby-images/4c263/4c263d66f417d68babf98f440bb239c98033a859" alt="The Code View for Form1"
At the top of the file, import the random
module:
import random
And at the end of the __init__
method, write these lines:
base_number = random.randint(1, 100)
app_tables.square_numbers.add_row(base_number=base_number, squared=base_number**2)
Run your app
Now click the ‘Run’ button at the top of the screen.
data:image/s3,"s3://crabby-images/050f9/050f9c3e00330a2f7b73578da26b5f9f2fc5beb3" alt="Running your app in the editor"
Stop the app and look back at the Data Tables service. Your table now contains some data.
data:image/s3,"s3://crabby-images/d9ce2/d9ce2a5582eefa620bf91c81e78fefd8232a73b8" alt="The Run button in the editor"
Stop the app and look back at the Data service. Your table now contains some data.
Run your app a few times to get some more data in the database.
data:image/s3,"s3://crabby-images/c400d/c400d9fd4c5bd71584119c89c8362bbb18c39573" alt="The Data Tables Service UI showing data in the table"
data:image/s3,"s3://crabby-images/bfd65/bfd65772d96fdeab91d837a5bfe8e9d4ce80c4e9" alt="The Data Service UI showing data in the table"
Read from the database
Go back to the Code View for Form1 and add these lines to the end of the __init__
method:
for row in app_tables.square_numbers.search():
print(f"{row['base_number']} squared is {row['squared']}")
Run your app again and you’ll get the contents of your table printed to the Output Panel.
data:image/s3,"s3://crabby-images/ffd7d/ffd7dfeee763ecc67e4ac1f3c4178fdb4913b229" alt="The Data Tables data printed in the Output Panel"
Run your app again and you’ll get the contents of your table printed to the App Console.
data:image/s3,"s3://crabby-images/dec14/dec14d1e213b4a0c7a24cbae8c3f3ed83d973ceb" alt="The Data Tables data printed in the App Console"
Copy the example app
Click on the button below to clone a finished version of this app into your account.
Next up
Want more depth on this subject?
Read more about databases.
Read more about Data Tables.
Want another quickstart?
Every quickstart is on the Quickstarts page.
Do you still have questions?
Our Community Forum is full of helpful information and Anvil experts.