Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Db2 REST APIを使ってみよう! 〜Db2 on Cloud編〜 / 20230727...

Db2 REST APIを使ってみよう! 〜Db2 on Cloud編〜 / 20230727 Db2 REST API

2023/07/27(木) オンライン開催
Db2 REST APIを使ってみよう! 〜Db2 on Cloud編〜
https://ibm-developer.connpass.com/event/288544/
の資料です。

Avatar for Kyoko Nishito

Kyoko Nishito

July 27, 2023
Tweet

More Decks by Kyoko Nishito

Other Decks in Technology

Transcript

  1. IBM Database Dojo, July 27, 2003 Db2 REST APIを 使ってみよう!

    〜Db2 on Cloud編〜 ⻄⼾ 京⼦ Kyoko Nishito ⽇本アイ・ビー・エム株式会社 テクノロジー事業部 Data & AI Technical Sales
  2. github.com/kyokonishito 2 twitter.com/KyokoNishito www.linkedin.com/in/kyokonishito qiita.com/nishikyon speakerdeck.com/kyokonishito ⻄⼾ 京⼦ ⽇本アイ・ビー・エム株式会社 テクノロジー事業部

    Data & AI Technical Sales ⽇本IBMにて主にIBMの社内システム開発・保守に従事し、要件定義か ら保守まで、開発者・PM・アーキテクトとして⽇本、AP各国の⽣産管 理システムや購買システム、IT資産管理システム 等、幅広く経験してき ました。その後IBM Developer Advocateとして開発者への啓蒙活動を ⾏っていました。 現在はData and AI テクニカルスペシャリストやっています。 2020/2021/2022/2023 Women in Data Science Tokyo @ IBM 開催 第 17 回 ⽇本統計学会統計教育賞 受賞 IBM Data & AI / 2023 IBM Corporation
  3. 本⽇の⽬的とゴール ⽬的: • Db2 REST APIの使い⽅を学ぶ ゴール: • Db2 REST

    APIの使い⽅がなんとなくわかって、使いたくなった時に資料を⾒なが ら実装できるようになる 3 IBM Data & AI / 2023 IBM Corporation
  4. 本⽇のタイムテーブル 4 IBM Data & AI / 2023 IBM Corporation

    17:00-18:00 (60min) Db2 REST APIを使ってみよう! 〜Db2 on Cloud編〜 • イントロダクション • 実際にやってみましょう! • まとめ • Q&A
  5. Db2 REST API Db2ドライバー/クライアントをインストールせずに、 REST HTTPクライアントからDb2へSQL実⾏、操作、管理が可能 IBM Data & AI

    / 2023 IBM Corporation 6 Db2 REST Service Db2 Db2 https JDBC PC、サーバー スマートフォン IoT機器など Db2 RESTサービスは コンテナ化されており、 DockerやOpenSift上で 動作します Db2 Db2 Db2 on Cloud Db2 Warehouse on Cloud Db2 U コンテナ版 Db2 SW 版 JDBC REST endpoint REST Endpoint https 要セットアップ セット アップ 不要 セット アップ 不要 https
  6. Db2 REST APIの利点 IBM Data & AI / 2023 IBM

    Corporation 7 ⭐Db2ドライバー/クライアントがないOSや、導⼊できない環境でもDb2操作が可能 • スマートフォンやIoT機器、ローコードツールなど • Linuxの標準的なコマンドcurlにて操作可能 ⭐通信ポートは通常通信可能に設定されていることが多い443番(https)が使⽤可能 なのでDb2のために特別なfirewall設定が不要 ⭐どの開発⾔語でも共通仕様 ⭐Cloud環境特有: GUIでしかできないの管理操作ができる(ユーザー作成など)
  7. Db2 REST APIの仕様 IBM Data & AI / 2023 IBM

    Corporation 8 • Db2 SW版、Db2 on Cloud版、Db2 Warehouse on Cloud版でそれぞれちょっとづつ違います。 Db2 SW版 version 1.0.0 https://www.ibm.com/docs/ja/db2/11.5?topic=applications-rest- endpoints ↕(似てるけど結構違いあり) Db2 on Cloud版 /dbapi/v4 https://cloud.ibm.com/apidocs/db2-on-cloud/db2-on-cloud-v4 ↕(だいたい同じ, パラメーターがちょっと違う) Db2 Warehouse on Cloud版 /dbapi/v4/ https://cloud.ibm.com/apidocs/db2-warehouse-on-cloud/db2- warehouse-on-cloud-v4 Db2 SW版 API Doc (導⼊しないと読めない)
  8. Db2 REST APIの仕様 IBM Data & AI / 2023 IBM

    Corporation 9 • Db2 SW版、Db2 on Cloud版、Db2 Warehouse on Cloud版でそれぞれちょっとづつ違います。 Db2 SW版 version 1.0.0 https://www.ibm.com/docs/ja/db2/11.5?topic=applications-rest- endpoints ↕(似てるけど結構違いあり) Db2 on Cloud版 /dbapi/v4 https://cloud.ibm.com/apidocs/db2-on-cloud/db2-on-cloud-v4 ↕(だいたい同じ, パラメーターがちょっと違う) Db2 Warehouse on Cloud版 /dbapi/v4/ https://cloud.ibm.com/apidocs/db2-warehouse-on-cloud/db2- warehouse-on-cloud-v4 Db2 SW版 API Doc (導⼊しないと読めない) TODAY
  9. Db2 on Cloud REST API https://cloud.ibm.com/apidocs/db2-on-cloud/db2-on-cloud-v4 IBM Data & AI

    / 2023 IBM Corporation 10 • 導⼊や設定は不要でいつでも使⽤可能 • 使⽤の際必要な情報は以下 • Db2 REST Service URL • Db2 on Cloud Web UIの「管理」→ 「接続」から取得 • ターゲットのDb2 on CloudのCRN • IBM Cloudのリソースリスト または • Db2 on Cloud Web UIの「製品情報」の「名前」から取得 • ターゲットのDb2 on Cloudの • useridとパスワード
  10. Db2 REST Service URL IBM Data & AI / 2023

    IBM Corporation 11 https://qiita.com/nishikyon/items/cf45ffa83334444674dc#11-rest-api-host-name%E6%83%85%E5%A0%B1%E3%81%AE%E5%8F%96%E5%BE%97 Db2 Webコンソール 管理 ↓ 接続 ↓ REST API host name
  11. ターゲットのDb2 on CloudのCRN IBM Data & AI / 2023 IBM

    Corporation 12 https://qiita.com/nishikyon/items/cf45ffa83334444674dc#12-crn%E6%83%85%E5%A0%B1%E3%81%AE%E5%8F%96%E5%BE%97 IBM Cloudのダッシュ ボード リソース・リスト ↓ 接続したいDb2の名前 の⾏の「真ん中あた り」をクリック ↓ CRN このあたりを クリック
  12. ターゲットのDb2 on Cloudのuseridとパスワード IBM Data & AI / 2023 IBM

    Corporation 13 https://qiita.com/nishikyon/items/69fee851849e7ef7e163#ibm- cloud%E3%82%B3%E3%83%B3%E3%82%BD%E3%83%BC%E3%83%AB%E3%81%8B%E3%82%89%E8%B3%87%E6%A0%BC%E6%83%85%E5%A0%B1%E3%8 2%92%E4%BD%9C%E6%88%90%E5%8F%82%E7%85%A7lite%E3%83%97%E3%83%A9%E3%83%B3%E3%81%AE%E5%A0% IBM Cloudのダッシュボード リソース・リスト ↓ 接続したいDb2の名前をクリック ↓ サービス資格情報 ↓ 資格情報がない場合は、「新規資格情報」をクリックして作成する ↓ サービス資格情報をクリックして、内容を表⽰
  13. Db2 on Cloud REST API Doc 読み⽅https://cloud.ibm.com/apidocs/db2-on-cloud/db2-on-cloud-4 IBM Data &

    AI / 2023 IBM Corporation 14 リクエストURL(REST APIエンドポイント)の組み⽴て https:// + [Db2 REST Service URL] + /dbapi/v4 + [API⽤URL⽂字列] Headerに⼊れるべき内容 content-type: application/json x-deployment- id: {DEPLOYMENT_ID} ({DEPLOYMENT_ID}の値はCRNの値) [request method] Request Bodyの仕様 Response Bodyの仕様 戻る可能性のあるStatus Code [API⽤URL⽂字列]
  14. Db2 on Cloud REST API 使⽤⼿順 https://cloud.ibm.com/apidocs/db2-on-cloud/db2-on-cloud-v4 IBM Data &

    AI / 2023 IBM Corporation 15 1. REST APIでアクセス・トークンの取得 https://cloud.ibm.com/apidocs/db2-on-cloud/db2-on-cloud-v4#authenticate IBM Cloud上のサービスでRESTAPIを使⽤するためにアクセス・トークンの取得が必要です • アクセス・トークンを⼀度取得すれば、有効期間中は同じものが使⽤可能です • アクセス・トークンが有効なのは 1 時間ですが、必要に応じて再⽣成可能です 2. 必要なREST APIの実⾏ • 1で取得したアクセス・トークンをHeaderにセットして、REST APIを実⾏します • ⽬的によっては、複数回リクエストが必要な場合があります • SQLの実⾏結果を得るには最低2回のリクエストが必要です
  15. 参考: Db2 on Cloud REST API List https://cloud.ibm.com/apidocs/db2-on-cloud/db2-on-cloud-v4 IBM Data

    & AI / 2023 IBM Corporation 16 https://github.com/kyokonishito/Db2onCloud_RESTAPI/blob/main/db2_on_cloud_rest_api_list.md に⼀覧を作りました。 ということで、 実際にやってみましょう!
  16. 事前準備が実施済みの状態から始めます! IBM Data & AI / © 2023 IBM Corporation

    18 https://ibm.box.com/v/20220421-dojo-prep • Db2 on Cloudのライトプランサービス作成 • Db2 on Cloudの資格情報の作成 • Watson Studio のライトプランサービス作成 • Watson Studio(またはCloud Pak for Data)プロジェクト作成 と設定
  17. 1. データの準備 IBM Data & AI / © 2023 IBM

    Corporation 19 東京都のオープンデータ 東京都卸売市場⽇報(販売予定数量・⽔産) https://catalog.data.metro.tokyo.lg.jp/dataset/t000013d0000000005/resource/90f272ac-ef4c-4a9b- ad82-b4e183becfdfのcsvファイルを取得します。 以下のURLからファイルestimate_quantity_fish.csvをダウンロードして保存してください。 (右クリックで「リンク先を保存」のようなメニューで保存する) http://www.opendata.metro.tokyo.lg.jp/shijyou/202303/estimate_quantity_fish.csv
  18. 2. IBM Cloudにログイン • IBM Cloud ログイン IBM Cloud Account(登録したメールアドレス)を⼊れてログインしてください。

    https://cloud.ibm.com/loginにアクセスしてログインします。 IBM Data & AI / © 2022 IBM Corporation 20
  19. Qiita: Db2 on Cloud: Web管理コンソールの表⽰ https://qiita.com/nishikyon/items/2d00ba97a66838742320 に従って、 Db2 on Cloud:

    Web管理コンソールを表⽰してください 3. Db2 on Cloud: Web管理コンソールの表⽰ IBM Data & AI / © 2023 IBM Corporation 21
  20. Qiita: Db2 on Cloudにテーブル作成 https://qiita.com/nishikyon/items/f13e376b00daaa71adeb に従って、 Db2 on Cloudにテーブル作成してください。 ただし、「

    4. CREATE TABLE文を入力」は以下のSQLを使⽤してくだ さい。 4. Db2 on CloudにTOKYO_FISHテーブル作成 IBM Data & AI / © 2023 IBM Corporation 22 CREATE TABLE "TOKYO_FISH" ( "分類" VARCHAR(12 OCTETS) , "市場" VARCHAR(30 OCTETS) , "⽔産市場ID" VARCHAR(10 OCTETS) , "⽇付" DATE , "種別" VARCHAR(24 OCTETS) , "品名" VARCHAR(60 OCTETS) , "販売⽅法" VARCHAR(24 OCTETS) , "卸売予定数量(t)" DECIMAL(5,1) );
  21. Qiita: Db2 on Cloud上のテーブルにCSVファイルをロードする https://qiita.com/nishikyon/items/f13e376b00daaa71adeb に従って作成したTOKYO_FISHテーブルに1でダウンロードしたCSV ファイルestimate_quantity_fish.csvをロードしてください。 すでにテーブルは作成済みなので 1、2、3 4-b

    5、6を実施します。 5. 作成したTOKYO_FISHテーブルにCSVファ イルをロードする IBM Data & AI / © 2023 IBM Corporation 23 本来、ここはREST APIでできるのですが、LiteプランではできなかったためGUIでロードしています。 StandardプランおよびEnterpriseプランの場合は以下に⽅法があるのでぜひ後でやってみてください。 Qiita: Db2 on CloudのREST APIを使⽤したデータロード (python & curl) https://qiita.com/nishikyon/items/cf45ffa83334444674dc
  22. 3. Launch in IBM Cloud Pak for Dataを選択して起動 (新しいブラウザが開きます) 6.

    Watson Studioの起動 IBM Data & AI / © 2023 IBM Corporation 26
  23. 8. セッション⽤のNotebookを開く 3. 「URLから」をクリック 4. 名前に Db2_Dojo_RESTAPI と⼊⼒ 5. Notebook

    URLに以下をコピー&ペーストで⼊⼒ https://github.com/kyokonishito/Db2onCloud_RESTAPI/blob/main/notebooks/Db2_Dojo_RESTAPI.ipynb 6. 「作成」をクリック 当セッションで使⽤する notebookが読み込まれます。 IBM Data & AI / © 2023 IBM Corporation 32
  24. 以後はNotebookで説明します IBM Data & AI / © 2023 IBM Corporation

    34 Notebookのソース: https://github.com/kyokonishito/Db2onCloud_RESTAPI/blob/main/notebooks/Db2_Dojo_RESTAPI.ipynb
  25. まとめ • Db2 REST APIの利点はDb2ドライバー/クライアントがない環境でもDb2にアクセ ス可能 • REST APIを使うには、まずはアクセストークンを取得 •

    リクエストURL(REST APIエンドポイント)の組み⽴て • https:// + [Db2 REST Service URL] + /dbapi/v4 + [API⽤URL⽂字列] • アクセストークンをRequest Headerにセットして、 API Docを参照しPOSTの場合はdataをRequest Bodyセットして GETの場合はURLにセットして API Docに書かれてるメソッド(get, postなど)でリクエストURLにアクセス IBM Data & AI / © 2022 IBM Corporation
  26. ⽇程: 2023年10⽉31⽇(⽕) -11⽉1⽇(⽔) 会場:ベルサール東京⽇本橋 主催:⽇本IBM株式会社 対象者: IBMのサービス/製品 を使⽤または使⽤検討されてい る技術者の⽅々 IBM

    TechXchange Conference Japan コンセプト:IBMの製品とソ リューションを軸に技術者同 ⼠が繋がり、学びや技術体験 をいただけます 概要:IBM製品および ソリューションを使⽤する技 術者のために企画された技術 学習イベントです。 技術ブレイクアウト セッショ ン、製品デモンストレーショ ン、ハンズオン、ネットワー キングの場を提供します お申し込み:7⽉31⽇ 開始予定
  27. ⽇本IBM Db2 & Databaseコミュニティ/各種イベントご紹介 Db2 およびDB各製品に関連するコミュニティ活動および各種イベントをさらに強化して参ります。 最新の情報を鮮度⾼くお届けできるよう活動して参ります、多くのご参加をお待ちしております。 IBM Data Management

    Community ⽇本IBM Db2& Databaseユーザーグループ IBM Database Dojo l Db2を中⼼としたIBMのデータベース製品に関 する技術情報の発信・共有、イベント案内、技 術者同⼠の交流を⽬的としています。 Ø Db2/Db2 Warehouse/Netezza/EDB/Watson Query... l 対象者︓Db2、他IBMのデータベース製品の提 案/ 構築に関わっている技術者や興味をお持ち の⽅はどなたでもご参加いただけます。 是⾮ご参加ください! https://ibm.biz/jpibmdb lDb2を中⼼としたIBMデータベースの技術情報、デモ、 ハンズオンセッション、お客様事例のご紹介をオンライ ンにて実施 l2022年シーズン1のシリーズよりこちらに公開しており ます。 l資料や録画もconnpassで公開中︕ ibm.biz/connpass-database-dojo Membersタブを 選択後 IBMID で ログイン、 をクリック!!