#経緯
JavaアプリでDB2に画像を保存するアプリをつくってみました。その備忘録をここに載せておきます。これからBluemixでJavaアプリを作ってみるという方がいらっしゃいましたらご参考頂ければと思います。複数回に分けて奮闘している様子をお届けしていこうと思います。
#レシピ
- IBM Bluemixアカウント
- Ecilpse
- 保存したい画像
#下ごしらえ
-
IBM Bluemixのアカウントを取得
こちらのサイトを参考にBluemixのアカウントを取得してください。30日間のフリーアカウントが利用可能です。30日を越えてもクレジット登録さえ行えば、無料枠の範囲でも個人利用であれば十分遊べるものシロモノです。 -
Eclipse Bluemix Plugin Toolのインストール
Eclipseを起動後、Help > Eclipse Marketplace からEclipse Marketplaceにアクセスし、検索バーから"IBM Eclipse Tools for Bluemix"を見つけたら、インストールをクリックしインストールをしてください。
(私のはすでにインストール済みなので表記がInstalledになってます。)
#手順
それではさっそく作っていきます。手順の概要をザックリと。
1. Bluemix上にWebサーバーとDBサーバーを用意(第一回)←いまここ
2. Javaアプリを用意(第二回)
3. BluemixのDBサーバーに画像をアップロード(第三回)
4. libertyサーバーをBluemixにプッシュ(第四回)
1.WebサーバーとDBサーバーの作成
Bluemixにログイン後、カタログからログイン。ボイラーテンプレートから、Java DB Web Starterをクリックをクリック。これで、IBM WebSphere Liberty Profile、つまりWebSphere Application Serverのクラウド版がささっと立ち上げます。
←こちらのアイコン(2015年9月時点)
さらにSQL Database(DB2)もバインドされた状態で立ち上がるため、WASとDB2のミドルウェアを史上最速のスピードで利用に可能になる環境です。しかも無料で。(こちらも無料枠内で十分遊べます。)
アプリが稼働するので公開されたURLをクリックし、Welcom画面が正常に表示されることを確認してください。正しく稼働すると以下のような画面になります。
2. SQL Databseのテーブル作成
SQL Databaseにテーブルを作成してみましょう。
アプリケーションの概要からSQL Databaseをクリック。
SQL Databaseの管理コンソールを立ち上げますので画面右側になるLAUNCHをクリック。
スタート画面から、Manage > Work with Tables をクリック。
以下のようなテーブル定義で作成していこうと思います。
Column Name | Data Type | Length | Scale | Alow Nulls |
---|---|---|---|---|
CONTACT_ID | INTEGER | 4 | 0 | NO_TEXT |
FIRST_NAME | VARCHAR | 45 | 0 | YES_TEXT |
LAST_NAME | VARCHAR | 45 | 0 | YES_TEXT |
PHOTO | BLOB | 1048576 | 0 | YES_TEXT |
CONTACT_IDはアップロードするたびにシーケンスに追加されるように定義します。
デフォルトでは、ユーザー名がSchemaに割り当てられるので、こちらにテーブルを作成してみます。
左側のプラスをクリックしてTABLE作成のQueryを発行します。便宜上カラム名は小文字にしております。小文字でこのまま発行しても問題ありません。
CREATE TABLE CONTACTS (
contact_id INT NOT NULL
GENERATED ALWAYS
AS IDENTITY
(START WITH 1
INCREMENT BY 1
MINVALUE 1
NO MAXVALUE
NO CYCLE
NO CACHE
ORDER),
first_name VARCHAR(45) DEFAULT NULL,
last_name VARCHAR(45) DEFAULT NULL,
photo BLOB,
PRIMARY KEY (contact_id)
)
このままRUN DDLをクリックして、RUN DDL IS SUCCESSFUL!とうポップアップメッセージがブラウザに表示されれば成功です。
スキーマにCONTACSテーブルが作成されており以下のようにテーブルの定義がされていることを確認。
はい、問題なさそうです。
次回は、Javaアプリを作成していきます。