Adding new records to a Supabase database

Adding new records to a Supabase database

Chris Bongers
·Dec 6, 2021·

2 min read

Listen to this article

Yesterday we learned how to set up a basic Supabase database in our Next.js application.

We loaded a simple list of all countries, but as the explorers we are, we happen to stumble on some new land!

And deem this land Devtopia. However, how can we now push this new country into our list of countries?

Making sure the fields are not required

Since we will be only pushing a name to our database. We want to make sure the other fields are nullable.

To check this, log in to your Supabase app login and visit the table you are working on.

Click on the little arrow on your table and choose "Edit Table"

Supabase edit table

Within the screen that pops up, make sure only the name field is not-nullable. All other fields must be nullable.

Supabase check if nullable

Adding a new country field

We can introduce a new country form in our application. We add this above our existing ul list.

      placeholder='My Made Up Country'
      onChange={(e) => {
    <button onClick={() => addCountry(newCountry)}>Add</button>

The important parts here are the setNewCountry on the input onChange handler. And the button that executes addCountry on click.

This means we should define a state for the newCountry variable to capture it somewhere.

const [newCountry, setNewCountry] = useState('');

And then all we need to do is add the addCountry function.

const addCountry = async (countryName) => {
    let { data: country } = await supabase
      .insert({ name: countryName })
    setCountries([...countries, country]);

What we do here is query the Supabase table and insert a new country with a name. Then we invoke the setCountries state and pass the old state merged with the new country.

This will result in the country showing up at the bottom of our list!

Let's try it out.

Adding new records to a Supabase database

And there we go! We can now add data to our Supabase table.

You can find the completed code on GitHub.

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Did you find this article valuable?

Support Chris Bongers by becoming a sponsor. Any amount is appreciated!

See recent sponsors Learn more about Hashnode Sponsors
Share this