Replit.com is an awesome new browser based IDE where you can code alone or collaboratively with friends using their awesome multiplayer features! It's particularly useful for education, and sharing code examples with others.
They support a ton of different languages and execution environments and even recently introduced a simple key value store you can use to persist data.
As a Replit user, if you want to access larger amounts of data direct from your repl, or if you fancy accessing some super-powerful query tools, at some point you may want to start interacting with a relational database. Supabase is a good fit here; just like Replit, you don't need to worry about servers, and hosting, you can just click a few buttons and get a fully featured relational database which you can start communicating with directly from javacript, using supabase-js.
Here's how to start a Supabase + Node.js repl:
Sign up for replit.com and hit new repl in the top left
Select node.js, give it a name, and click Create repl
Import supabase's createClient method and hit run to install the required libs:
const { createClient } = require('@supabase/supabase-js')
Setup a new Supabase project and grab the URL and anon key from Settings > API. Create the client in javascript using:
const supabase = createClient(
'https://ajsstlnzcmdmzbtcgbbd.supabase.co',
'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...'
)
Now that supabase is connected you'll want to add some data to your db, you can grab any SQL dataset on the web, or make your own, but the fasted way to test is to open the SQL tab in the Supabase dashboard and click the Countries sample database and click Run.
From within your repl you can now query your countries table like:
// .then() syntax
supabase.
.from('countries')
.select('*')
.limit(5)
.then(console.log)
.catch(console.error)
// or...
// async/await syntax
const main = async() => {
let { data, error } = supabase
.from('countries')
.select('*')
.limit(5)
if (error) {
console.log(error)
return
}
console.log(data)
}
main()
Once this is working, if you want to learn more about the query interface you might want to try some of these challenges:
// 1. List all the countries in Antarctica
// 2. Fetch the iso3 code of the country with ID 3
// 3. List the countries with 'Island' in the name
// 4. Count the number of countries that start with 'Z' or 'Q'
// 5. Fetch all the Countries where continents is null
There are full solutions provided in the video version of this blog, but some examples you may find useful are:
// or
const { data, error } = await supabase
.from('cities')
.select('name, country_id')
.or('id.eq.20,id.eq.30')
// is
const { data, error } = await supabase.from('cities').select('name, country_id').is('name', null)
// in
const { data, error } = await supabase
.from('cities')
.select('name, country_id')
.in('name', ['Rio de Janeiro', 'San Francisco'])
// neq (not equal to)
const { data, error } = await supabase
.from('cities')
.select('name, country_id')
.neq('name', 'The shire')
// full docs here: /docs/reference/javascript/filter
We look forward to showing off some more Supabase + Replit examples.
You can find my example repl here: https://repl.it/@awalias/supabase-test#index.js
Supabase has a free tier, head over to https://app.supabase.com to get started.