こんにちは。ファンリピートの鳴海です。
今回はBubbleのプラグインにあるSQL Database Connectorの表示、作成、更新、削除までの使い方を実際にアプリを作って解説していきます。
bubbleとは?
data:image/s3,"s3://crabby-images/bc67c/bc67c5913d600dc6a7475225a642000edfb823f4" alt=""
URL:https://bubble.io/blog/content/images/2020/09/Logo-with-clearspace.png
コードを書かずにアプリを作れる
一般的なWebサービスやWebアプリの開発では、プログラミングコードを書くといったイメージがありますが、ノーコードツールBubbleでは名前の通り、ノーコードで開発できるサービスとなっています。
また、クラウドプラットフォームというサイト上でアプリケーションを構築できるので、インターネットがあればいつでもどこでもアクセスができるため、チームで連携してアプリを作れます。
bubbleについての詳細は「ノーコードツール「Bubble」って?特徴・料金・使い方を解説」という記事でも解説しておりますので、気になる方は一度ご覧になってみてください。
Bubbleのプラグインとは?
Bubbleの標準機能だけでも、ドロップダウンやチェックボックス、ホバー時のアニメーションなどを実装ができますが、プラグインを追加することによって、APIの呼び出しによるログイン認証の実装やデザインを簡易的に追加できます。
Bubbleの拡張機能
過去にBubbleのプラグインを使って、API経由でのフィルターやバーコードのスキャン、IPアドレス制限の実装方法を初心者でも分かりやすく説明をしているので、ぜひ下記をご覧ください。
記事参考リンク:
data:image/s3,"s3://crabby-images/98426/984260c2382341c61b368ebd6c38ec74c87bddbc" alt=""
data:image/s3,"s3://crabby-images/78e57/78e5759d3b2dcd6f5d3a5192b42dd1d306cb4307" alt=""
data:image/s3,"s3://crabby-images/b5bcf/b5bcf28d64f3214e13b73068906f3cc2313a75b7" alt=""
SQL Database Connectorとは?
データベースへ接続し、Bubble内でSQLクエリを実行することによって、データへの表示、作成、更新、削除などが可能になります。
本記事では、MySQLを使ってでの実装となりますが、他にもPostGres、Microsoft SQLへの接続もサポートしています。
下記、Bubbleのマニュアルから参照
MySQLとは?
世界でYouTubeやTwitter、facebookなどで最も使われているデータベースがMySQLとなります。
他にも、「Oracle」「PostgreSQL」などが使われておりますが、どちらもオープンソースとなっており、無料で使用できます。
環境構築の方法は?
基本的にMySQLを使うためには、公式サイトでファイルをインストールし、コマンドプロンプトで扱えるように設定するのが定番となっています。
ただ、設定する際にユーザー権限の設定やOSごとで準備が異なることやローカルPCでしか使えないということがあります。
ですが本記事では、自分のPC上ではなくクラウド上やアカウント作成するだけでユーザー情報の設定ができてしまう下記のサイトで環境構築を行います。
BubbleでMySQLを接続するメリット
そもそもBubbleというノーコードでアプリ開発できることがメリットなのですが、元々プログラミングで構成していたサイトをノーコードに移行する際や、ターミナルでわざわざデータに変更を加えたりするのが面倒の時に、Bubbleで手軽にできるのがメリットになるかなと思います。
SQL Database Connectorでアプリを作ってみよう
それでは初めにBubbleでアカウント登録を行います。
Bubble側で準備しよう。
Bubble側でアプリを登録する。
こちらのページにアクセスして、Get started for freeからアカウントを作成しましょう。
data:image/s3,"s3://crabby-images/ab9c2/ab9c2e870e0ef75516569e09383ab60da991682d" alt=""
data:image/s3,"s3://crabby-images/16432/16432dd640ba096afa3f8017ca5b8e64ab51fd71" alt=""
メールアドレスやパスワードを打ち込み、Start buidlingをクリックすると画像のようなポップアップが表示されるので、Build→Nextボタン→other→Completeと進めてください。
data:image/s3,"s3://crabby-images/0d5d1/0d5d1a28c1efc61b980bd0f4a1318d9bceb5666f" alt=""
そうすると登録したメールアドレスにメールが届くので、そちらをクリックしてあげてください。
data:image/s3,"s3://crabby-images/2cbad/2cbadbd077432a926dd4ce986dfbfe336459164f" alt=""
リンクをクリックすると、Start buildingのボタンがあるので、クリックしてください。
data:image/s3,"s3://crabby-images/88fe7/88fe72235cb64c762be0f715c20231d2feebc860" alt=""
トップページのCreate a new appをクリックし、Name your appで名前を決めて、他の項目を入力し、Create appをクリックすると編集画面に飛びます。
data:image/s3,"s3://crabby-images/218fb/218fb0d64a2b98528fbbe6fc588192b85a9e22db" alt=""
アシスタントというのが左側に表示されるので、Skip application assistantをクリックしてください。
data:image/s3,"s3://crabby-images/d90bd/d90bd2e9c0430e51133eac90da3df3cfd136addf" alt=""
これでアプリの登録が完了です。
Free MySQL Hostingでデータベースを作成しよう。
アカウントを作成しよう。
Start my Free Accountをクリックします。
data:image/s3,"s3://crabby-images/9f932/9f9327ad422c7ceecbdd846edde8e94f945d05d6" alt=""
下記の画面で、E-mailとCofirm E-mail Addressを入力し、Registerを押します。
data:image/s3,"s3://crabby-images/ae703/ae70354b39f4448400e941fa8f3e10c3b2b52ba3" alt=""
そうするとメールに確認メールが届くので、そちらをクリックします。
data:image/s3,"s3://crabby-images/a13cd/a13cd10927852d0e5c6873ea40d21d03576f4daf" alt=""
New passwordに任意のパスワードを入力して、Reset Passwordを押します。
data:image/s3,"s3://crabby-images/7be4b/7be4b32d142e9c823b79000999e371d5d533d729" alt=""
メールアドレスとパスワードを入力して、Log Inを押します。
data:image/s3,"s3://crabby-images/44486/44486b2717cc2366c9d057163dabc4e79ef41f99" alt=""
①Japanを選択します。
②チェックを外します。
③Complete my registrationを押します。
data:image/s3,"s3://crabby-images/014a4/014a4ed0c84bdfe066ffc41143570a1c84f82ffb" alt=""
①Asia Pacificを選択して、Save Locationを押します。
②Start new databaseを押します。
data:image/s3,"s3://crabby-images/78ed7/78ed702f5ee2d1110d6110892737d1f7d1b420e2" alt=""
そうするとデータベースが作成されて、しばらくするとphpmyadminへログインするためのログイン情報がメールで送られてきます。
data:image/s3,"s3://crabby-images/68b80/68b8076ce691b49d5bfcdc7a7574e750841091e0" alt=""
Free MySQL Hostingの画面に戻り、Follow this link for phpMyAdminをクリックします。
data:image/s3,"s3://crabby-images/006d8/006d88e70fd1fae449004155aa28ca76a329c627" alt=""
送られたメールにサーバ、ユーザー名、パスワードがあるので、そちらを入力し、実行ボタンを押します。
data:image/s3,"s3://crabby-images/32a90/32a9050e36220dd97bdc8ceaabdb2ada3c3da181" alt=""
下記のような画面になれば、登録完了です。
data:image/s3,"s3://crabby-images/520fe/520fe945b26979d8b3387044b96725ab52e41ca0" alt=""
phpMyAdminでデータを追加しよう。
左のデータ名をクリックします。
data:image/s3,"s3://crabby-images/d56fa/d56fae559d9e730798bbd928805b2e01379cb364" alt=""
①テーブル名を決めます。
私は食べ物のデータベースを作りたいので、foodにしました。
②カラム数を4にします。
③実行ボタンを押します。
data:image/s3,"s3://crabby-images/e73bf/e73bfb3649a1e8f9ed7661f3f68e19a28bf8d2ea" alt=""
①名前をname、データ型をTEXTにします。
②名前をpriceにします。
③名前をamountにします。
④名前をidにして、インデックスをPRIMARYにし、A_Iにチェックを入れます。
保存するを押します。
data:image/s3,"s3://crabby-images/c9be8/c9be8fe9d842734fb51e76dc68e96d43c7070a70" alt=""
カラムが生成されていることを確認できたら、上の挿入を押します。
data:image/s3,"s3://crabby-images/d11c5/d11c57d0acae56fe5209fcb2ba6d35cf2741e928" alt=""
それぞれ値を入力し、実行ボタンを押します。idでは番号が自動生成されるので、入力しなくても問題ありません。
data:image/s3,"s3://crabby-images/50d3d/50d3d3d8819a666e7af44d53dbf460bef72646ce" alt=""
上の表示を押して、データが挿入されていたらOKです。
data:image/s3,"s3://crabby-images/673d2/673d27cf8fbc032edffe2d3f31c07d4467a64a43" alt=""
SQL Database ConnectorとphpMyadminを接続しよう。
プラグインを追加しよう。
左タブのPluginをクリックしてください。
data:image/s3,"s3://crabby-images/4f116/4f116f688a688044e2dbc1aa93cae5d89a7720e7" alt=""
Add pluginsを押してください。
data:image/s3,"s3://crabby-images/15590/155903a603f43240e7c523908ed2e0379f0d566f" alt=""
左でSQL Database connectorと検索し、該当してでてきたものをInstallします。
data:image/s3,"s3://crabby-images/1c76f/1c76f3c04f26acda156c1692898d77bf8725044b" alt=""
これでプラグインのインストールは完了です。
接続しよう。
Add a new connectionを押します。
data:image/s3,"s3://crabby-images/d9411/d94118e644d6d74d4fb4dc39e8b12a0fa923531e" alt=""
①Connection nameを任意の名前にします。
②Database typeをMySQLにします。
③mysql://と入力します。
data:image/s3,"s3://crabby-images/31d97/31d97d29787b9419bc592d4348f079ae85ff7581" alt=""
mysql://の続きでは、①:②@③:④/⑥となるように入力します。
data:image/s3,"s3://crabby-images/d0530/d053033e6164d47c5263f281430b105d64f87d3b" alt=""
Test the connectionを押して、Database connectedになれば接続完了です。
data:image/s3,"s3://crabby-images/bbd09/bbd09895f3ed52be2d178a0e656b44d1ef3e49c0" alt=""
データを表示できるようにしよう。
plugins側で設定しよう。
Add a new queryを押します。
data:image/s3,"s3://crabby-images/55bbd/55bbdda7d449423d435af7be34ed2e58b7203043" alt=""
①任意の名前にします。
②Use asをDataにします。
③下記の通りにします。
SELECT * FROM `food` ORDER BY `id` DESC LIMIT 200
④Initialize this queryを押します。
data:image/s3,"s3://crabby-images/f31f7/f31f7f35b544ca6ee66b76b25ed3222bcd7cd7b3" alt=""
全てtextにし、SAVEを押します。
data:image/s3,"s3://crabby-images/ccc20/ccc20652cef35d1ad1194bb4f3868c0f34f8d916" alt=""
これでプラグイン側での設定は完了です。
designを設定しよう。
Designタブを押します。
data:image/s3,"s3://crabby-images/1b3ca/1b3ca4011189e337e10f988360ea2c0c7ea80b05" alt=""
①Repeating Groupを設置します。
②①の列内にGroupを設置します。
data:image/s3,"s3://crabby-images/6bdc0/6bdc0bea962656576440c70a3c01e2066172b08b" alt=""
テキストを3つ設置します。
data:image/s3,"s3://crabby-images/43c31/43c31954d2a8f8182cb9cfffff236c31bd6bb2dc" alt=""
Repeating groupをクリックし、Type of contentをselectにします。
Data sourceでは、Get Data from an external APIを選択し、API providerでselectを選択します。
data:image/s3,"s3://crabby-images/b4648/b46485e5c14bddd14b692dcc88eccf3d351eeff1" alt=""
Groupでは、Type of contentをselectにし、Data sourceをCurrent cell’s selectにします。
data:image/s3,"s3://crabby-images/749f6/749f6d67779b95fea6157aba3160666833aa5d09" alt=""
テキストエレメント内には、Insert DynamicでそれぞれParent group’s select’sでName、Price、Amoutに設定してください。
data:image/s3,"s3://crabby-images/73d47/73d4767846d69d3783b1ddca7bf63d049a7d9d69" alt=""
プレビューを押して、データが表示されていればOKです。
data:image/s3,"s3://crabby-images/e9ee0/e9ee0af89d134c29ef6e247cc9c4eab2c0d64470" alt=""
データを作成できるようにしよう。
plugins側で設定しよう。
Pluginsの画面に戻り、Add a new queryを押します。
data:image/s3,"s3://crabby-images/6e12b/6e12bd0ec713d078489d89eb17943b424d3ad0b8" alt=""
①Nameではinsertにします。
②Use asではActionを選択します。
③Queryでは下記の通りに入力します。
INSERT INTO `food` (`name`, `amount`, `price`) VALUES (?,?,?);
④Parametersでは、Name、amount、priceを追加します。Test Valueではそれぞれ任意の値を入れます。
⑤Initialize this queryを押します。
data:image/s3,"s3://crabby-images/c871c/c871c8fee4dfca4f42ea067c9f3b217f24e0eece" alt=""
エラーがでなければ、これで設定は完了です。
designを設定しよう。
Design画面に戻ります。
①Groupエレメントを設置します。
②①内にInputエレメントを3つ設置します。
③①内にButtonエレメントを1つ設置します。
data:image/s3,"s3://crabby-images/10670/106705a082397326a24822b278d1e9e962229f95" alt=""
それぞれplaceholderを画像の通りに変更します。
data:image/s3,"s3://crabby-images/84fb7/84fb77ed5a20dbd5370ed915cd279c81af12e549" alt=""
次にButtonのWorkflowを開きます。
data:image/s3,"s3://crabby-images/3cd56/3cd561007ad829b81c5abf88c35b2e03a98463f8" alt=""
Data(things)からinsertを選択します。
data:image/s3,"s3://crabby-images/35c49/35c49a707b0429cec33fc14c65172937899be6cd" alt=""
Step1では、画像の通りにinsert dynamicで入力します。
data:image/s3,"s3://crabby-images/b360b/b360bd81798c76035ea58ca3a4023020d9d074d8" alt=""
Step2では、Reset relevant inputsを選択します。
data:image/s3,"s3://crabby-images/9dd53/9dd53bfe28eeb8a13c541ee32ae8c5f2d2575d90" alt=""
Step3では、データの更新したとしてもbubble側での読み込みが遅い可能性があるので、Refresh the pageを選択します。
data:image/s3,"s3://crabby-images/89bae/89baed276678de7fcb0f9a5afaea4127e23ef7fb" alt=""
プレビューで表示してみて、データを挿入できていればokです。
data:image/s3,"s3://crabby-images/a9b36/a9b36fe21a07727ff0c76215fc5a1ad7288ad975" alt=""
データを編集できるようにしよう。
plugins側で設定しよう。
pluginsの画面に戻ります。
Add a new queryを押します。
data:image/s3,"s3://crabby-images/a2a0a/a2a0ae3edabb2a36820340be4649cefa8507c7e3" alt=""
①updateにします。
②Use asをActionにします。
③Queryに下記の通りに入れます。
UPDATE `food` SET name = ?, amount = ?, price = ? WHERE id = ?;
④Parameterにはカラムの通りに入力し、Text valueはphpMyadminで最初に追加データを指定します。
⑤Initialize this queryを押します。
data:image/s3,"s3://crabby-images/fa94f/fa94ff827cb581cb8daf79df67511e25403159fe" alt=""
エラーがでなければOKです。
designを設定しよう。
Desingタブに戻ります。
Repeating group内にInputエレメント4つ配置し、Buttonエレメントを1つ配置します。
data:image/s3,"s3://crabby-images/4a673/4a673b656af6d55e9199d63a944492c2b00793cb" alt=""
それぞれエレメント名を変更し、initial contentをParent group’s select’s Name、price、amout、idという形にInsert dynamic dataで挿入します。
data:image/s3,"s3://crabby-images/d7012/d701213da17a2f507066b4f11c5a3d6410d7ead1" alt=""
変更するボタンのWorkflowを開きます。
data:image/s3,"s3://crabby-images/8c965/8c965ddb087e15cd0e8c519231e40b9591041014" alt=""
Data(things)のupdateを選択します。
data:image/s3,"s3://crabby-images/599c3/599c3172994216a0bb12fcb67945e821dbc9d2a1" alt=""
それぞれ変更したエレメント名通りに挿入します。
data:image/s3,"s3://crabby-images/14f50/14f5092489c09cefa7c0080753c16dbe91024649" alt=""
Step2ではRefresh the pageを選択します。
data:image/s3,"s3://crabby-images/29790/29790b0b4b2fc3dfe27611d98bfe9ec3bc2b9948" alt=""
これでプレビューを押して、inputに表示されている値を変更し、変更するボタンを押すと値が変わっていると思います。
尚、idの値を変えてしまうとSQLでWHEREの条件式から外れてしまうので、変更してはいけないので気をつけてください。
data:image/s3,"s3://crabby-images/797fd/797fda2164a869d145011aa224d1a5469fb82c68" alt=""
データを削除できるようにしよう。
plugins側で設定しよう。
pluginsの設定画面を開きます。
Add a new queryをクリックします。
data:image/s3,"s3://crabby-images/996f0/996f01afde92b678d5968249036e48c40bd91fd7" alt=""
①nameをdeleteにします。
②Use asをActionにします。
③Queryを下記の通りにします。
DELETE FROM `food` WHERE id = ? ;
④Parametersに画像の通りに入力します。Test valueには存在しているidを入力してください。
⑤Initialize this queryをクリックします。
data:image/s3,"s3://crabby-images/af937/af9375a8259ad7dc0c3f08bbd2684d0f5c31655a" alt=""
エラーがでなければ、OKです。
designを設定しよう。
Desing画面を開きます。
Group内にButtonエレメントを設置し、削除すると入力します。
data:image/s3,"s3://crabby-images/bdd2f/bdd2f9908a6f7d11f5bb6a2efdad07f963948830" alt=""
ボタンの色を変更したいので、Edit styleをクリックします。
data:image/s3,"s3://crabby-images/2779e/2779e27adb20391205f803ca7148284d8cb3ded2" alt=""
Add styleを押します。
data:image/s3,"s3://crabby-images/eade7/eade785d8339a79d5ca3f54244a2465a91445d96" alt=""
Style nameをRed button、Element styleをButtonにし、CREATEを押します。
data:image/s3,"s3://crabby-images/c12e5/c12e512d1db67a07fdd9936902b75d1be2704e94" alt=""
colorを変更します。
data:image/s3,"s3://crabby-images/b7a27/b7a2764249900da7393f073539b86ab136b24e54" alt=""
Desing画面に戻り、StyleをRed Buttonに変更します。
data:image/s3,"s3://crabby-images/3f807/3f807489b055897bed46d8fb2710d6bb94ccecea" alt=""
Workflowを開きます。
data:image/s3,"s3://crabby-images/2bce1/2bce1ba76aad42644a0400f492f86339cc0f7071" alt=""
Data(Things)からdeleteを選択します。
data:image/s3,"s3://crabby-images/36df9/36df99f5c2d593579a556ac9179d028adabc774f" alt=""
idは更新の際に作成したエレメントで問題ありません。
data:image/s3,"s3://crabby-images/1a9db/1a9db2f200f695fd59e6d7814403d6cb1f7bb815" alt=""
Step2に、Refresh the pageを選択します。
data:image/s3,"s3://crabby-images/1ad03/1ad03922fb62e06389d9d99b366fd4f0ad1a0658" alt=""
プレビューを開き、削除ボタンを押してデータが消えればOKです。
data:image/s3,"s3://crabby-images/8b882/8b88289e6d88b0cfe8ed6d3ebf90fc6e014b7ac8" alt=""
まとめ
今回はSQL Database Connectorというプラグインを使って、外部データベースと接続し、データ操作の実装しました。
本記事で紹介した操作以外でも複数データベースの操作や表示などもできそうなので、機会があったら紹介したいですね。
今後の可能性としては、前頭でも話した通り、プログラミング言語で作られたWebサイトでデータ操作する際に、Bubbleですと簡単にデータを扱うことができそうだと思いました。
以上で終わりたいと思います。ありがとうございました。