supabaseとは
supabase(スーパベース)はめちゃくちゃざっくりというと、firebaseのRDB版です。
Firebaseはとても魅了的なサービスですが、NoSQLということもあり用途が制限されますが、
supabaseはRDBのPostgreSQLが使えるので、この時点でテンションが上がりますよね。
supabaseの初期設定
アカウント登録
githubアカウントがあれば、すぐに利用開始できます。
プロジェクトの作成
New projectを押して、新規プロジェクトを作成します。
data:image/s3,"s3://crabby-images/dd514/dd514245b2f6abe3333c2200f912b0090fbc10eb" alt=""
プロジェクト名、データベースパスワード、リージョンを設定します。
data:image/s3,"s3://crabby-images/ab5d6/ab5d601de0dfe6fc0b8a2a8b607934b0a162ace1" alt=""
テーブルの作成
データベースとAPIが作成され、createa new tableからテーブルを作成します。
data:image/s3,"s3://crabby-images/5bb01/5bb014ac2afadb1f86e4e4415501a92ed9b0b772" alt=""
テーブル名などの情報を登録し、Save
data:image/s3,"s3://crabby-images/45d35/45d358830e265868d2e1295ec6bc7d12a7b729f9" alt=""
テーブルが作成できました。
data:image/s3,"s3://crabby-images/3a93d/3a93df41cb4931cde15c9b90cba4251242c67004" alt=""
カラムの追加
primary keyしかないので、New columnからカラムを追加します
nameとemailを追加しました。
data:image/s3,"s3://crabby-images/d3858/d3858e756d8f8c2229a865d414c9624916024b1a" alt=""
デモデータを追加する
Insert rowからレコードを追加できます
data:image/s3,"s3://crabby-images/53414/53414093cd67b31ee41f137b92a847b90e468176" alt=""
idはオートインクリメントなので、それ以外を入力します。
data:image/s3,"s3://crabby-images/a5b26/a5b2612bf19159a4509ec0c8fb05bc5eff8c713c" alt=""
追加できました。(認証は不要なので、パスワードとemailはいらないのですが、適当に作っておきました)
data:image/s3,"s3://crabby-images/edbe1/edbe19e0e9ac9b6bb149fc7986483ebeb00c1702" alt=""
リレーション(foreign keyの設定)
今回はリレーションのやり方も見ておきたいので、もう一つ、recipesテーブルを追加します。
data:image/s3,"s3://crabby-images/c762a/c762aa05c289bb7c0e52bd98822a297c3e4fd58e" alt=""
users.idをrecipesテーブルに外部キーとして貼りたいので、New columnを押し、user_idカラムを追加します。
追加する際、Add foreign key relationを押します。
data:image/s3,"s3://crabby-images/126ad/126ad818151c00a034963042cc48f6029be80ec7" alt=""
リレーションの対象テーブルとカラムを登録します。
data:image/s3,"s3://crabby-images/68d36/68d36e9fa89e521e960ba87e033d5536a830d26f" alt=""
これだけでリレーションの設定ができちゃいました。
data:image/s3,"s3://crabby-images/0548c/0548c254fe556c58d03625089623261b234f7de9" alt=""
recipesテーブルに3つレコードを追加しました。
data:image/s3,"s3://crabby-images/3a33e/3a33eb455a04f1b313379c497c3166c035e56be8" alt=""
Reactアプリから接続する
Reactアプリのセットアップ
create-react-app
create-react-appでreactアプリを作成する。
※create-react-appの詳細は割愛します。
Reactアプリにsupabaseの設定を追加
手順は、API / Introduction に丁寧に書いてくれています。
data:image/s3,"s3://crabby-images/dc749/dc74943cbf935dba2663c90fdd875c9d54a01c7d" alt=""
supabaseのインストール
npm install --save @supabase/supabase-js
supabase用設定ファイル
src/config.js
import { createClient } from "@supabase/supabase-js";
const supabaseUrl = "YOUR URL";
const supabaseKey = "YOUR APIKEY"
export const config = {
supabase: createClient(supabaseUrl, supabaseKey),
};
URLとsupabasekeyは以下から確認できます。
Setting / API
data:image/s3,"s3://crabby-images/42799/42799caab344e8eae1b4089f9660bcabaada18e3" alt=""
親コンポーネント(データ取得用)
データベースからユーザーIDが1のデータをフェッチして、stateに格納し、子コンポーネントに渡す
src/App.js
import { useEffect, useState } from "react";
import Recipe from "./Recipe";
// supabaseの設定ファイルをインポート
import { config } from "./config";
const App = () => {
const [recipeList, setRecipeList] = useState([]);
const supabase = config.supabase;
// 実際はfirebase authとかバックエンドのapiを叩いてユーザーidを取得
const userId = 1;
const fetchRecipes = async () => {
const reicpes = await supabase
.from("users")
.select(
`
id, name ,email, // usersテーブルで取得したいカラムを指定
// リレーション先のテーブルを指定
recipes(
user_id,recipe_name)
`
)
//
.eq("id", userId); // ユーザーIDを指定
// stateを更新
setRecipeList(reicpes.data);
};
useEffect(() => {
fetchRecipes();
}, []);
return (
{recipeList.length > 0 ? recipeList.map((data) => ( )) : "" );
};
export default App;
子コンポーネント(データイテレート用)
propsでデータを受け取ってユーザー名とレシピ一覧を表示
src/Recipe.js
const Recipe = (props) => {
return (
<div className="recipe">
<h4>ユーザー名:{props.username}</h4>
<h4>レシピ一覧</h4>
<ul>
{props.recipeList.map((recipe) => (
<li key={recipe.id}>{recipe.recipe_name}</li>
))}
</ul>
</div>
);
};
export default Recipe;
READ
ブラウザで確認
npm start
data:image/s3,"s3://crabby-images/9a2d3/9a2d3058b6273243a63f5a8061dc287a366cabab" alt=""
しっかりデータを取得できています。
data:image/s3,"s3://crabby-images/949f0/949f00a6cea27f474688675852ffbe971cae3db7" alt=""
CREATE
insertで追加できます
src/App.js
〜割愛〜
const App = () => {
〜割愛〜
const saveRecipe = async () => {
const newRecipe = await supabase.from("users").insert([
{
user_id: userId,
recipe_name: "味噌汁",
},
]);
return newRecipe;
};
return ( <div className="App"> {recipeList.length > 0 ? recipeList.map((data) => ( <Recipe key={data.id} username={data.name} recipeList={data.recipes} /> )) : "" } <button onClick={() => saveRecipe()}>レシピを追加する</button> </div> ); );
};
export default App;
まとめ
いかがでしたでしょうか。本記事では、今話題のBaaS「supabase」をReactで使用する手順について説明しています。supabase(スーパベース)はめちゃくちゃざっくりというと、firebaseのRDB版です。Firebaseはとても魅了的なサービスですが、NoSQLということもあり用途が制限されますが、supabaseはRDBのPostgreSQLが使えるので、この時点でテンションが上がりますよね。