PowerBuilder から JDBC 経由で Outlook のデータ に接続

Jerod Johnson
Jerod Johnson
Director, Technology Evangelism
PowerBuilder で Outlook JDBC Driver を使用して Outlook のデータ にアクセスする方法を紹介します。



CData JDBC ドライバー for Outlook は、 PowerBuilder を含む、JDBC をサポートするあらゆるプラットフォームや開発技術から使用できる標準ベースのコントロールです。 この記事では、PowerBuilder で CData JDBC Driver for Outlook を使用する方法について説明します。

ここでは、CData JDBC Driver for Outlook を使用してデータを取得する基本的な PowerBuilder アプリケーションの作成方法を説明します。

PowerBuilder から Outlook のデータ に接続

以下の手順に従って、Database Painter ツールを使用し、Outlook 用の JDBC URL に基づくデータベースプロファイルを作成します。データベースプロファイルを使用して接続プロパティを保存できます。Database Painter では、データをグラフィカルに操作したり、SQL クエリを実行したりできます。

  1. ドライバーの JAR ファイルを PowerBuilder のクラスパスに追加します。CLASSPATH システム環境変数を、インストールディレクトリの lib サブフォルダにあるドライバー JAR へのパスに設定します。

    Note: PowerBuilder Classic を使用している場合は、Tools -> System Options -> Java をクリックしてドライバー JAR へのパスを追加することもできます。

  2. Tools -> Database Painter をクリックします。
  3. JDBC ノードを右クリックし、New Profile をクリックします。
  4. Database Profile Setup ダイアログで、以下の情報を入力します。
    • Profile Name: プロファイルのわかりやすい名前を入力します。
    • Driver Name: ドライバーのクラス名を入力します: cdata.jdbc.api.APIDriver
    • URL: JDBC URL を入力します。

      OAuth 認証の設定

      Microsoft Graph API は認証に OAuth 2.0 を使用します。OAuth 認証情報(Client ID と Client Secret)を取得するには、Microsoft Azure Portal でアプリケーションを登録する必要があります。

      OAuth 認証情報の取得

      1. Azure Portal にログインします。
      2. Azure Active Directory > App registrations に移動します。
      3. New registration をクリックして新しいアプリケーションを作成します。
      4. アプリケーション名を入力し、適切なアカウントの種類を選択します。
      5. Redirect URI をアプリケーションのコールバック URL に設定します(デスクトップアプリの場合は http://localhost:33333 など)。
      6. Register をクリックしてアプリケーションを作成します。
      7. アプリケーションの概要ページで Application (client) ID をコピーします。これが OAuthClientId になります。
      8. Certificates & secrets に移動して、新しいクライアントシークレットを作成します。
      9. クライアントシークレットの値をコピーします。これが OAuthClientSecret になります。
      10. API permissions に移動して、必要な Microsoft Graph API の権限を追加します:
        • Mail.Read - メールメッセージへのアクセス用
        • Contacts.Read - 連絡先へのアクセス用
        • Calendars.Read - カレンダーイベントへのアクセス用
        • Tasks.Read - To Do タスクへのアクセス用
        • offline_access - リフレッシュトークンの取得用
      11. Grant admin consent をクリックして、これらの権限を付与します。

      OAuth での接続

      以下の接続プロパティを設定して接続を確立してください:

      • AuthScheme:OAuth に設定します。
      • InitiateOAuthGETANDREFRESH に設定します。CData API Profile for Outlook が OAuth プロセスを自動的に進め、アクセストークンを取得します。
      • OAuthClientId:Azure Portal の Application (client) ID に設定します。
      • OAuthClientSecret:Azure Portal のクライアントシークレットの値に設定します。
      • TenantId:Azure AD のテナント識別子(GUID または 'contoso.onmicrosoft.com' のようなドメイン名)に設定します。
      • CallbackURL:アプリ登録で指定したリダイレクト URI に設定します(デスクトップアプリの場合は http://localhost:33333 など)。

      接続文字列の例

      Profile=C:\profiles\Outlook.apip;AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;TenantId=your_tenant_id;CallbackUrl=http://localhost:33333;
      

      組み込みの接続文字列デザイナー

      JDBC URL の構築には、Outlook JDBC Driver に組み込まれている接続文字列デザイナーが便利です。JAR ファイルをダブルクリックするか、コマンドラインから JAR ファイルを実行します。

      java -jar cdata.jdbc.api.jar
      

      接続プロパティを入力し、接続文字列をクリップボードにコピーします。一般的な JDBC URL は以下のとおりです。

      jdbc:api:Profile=C:\profiles\Outlook.apip;AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;TenantId=your_tenant_id;CallbackUrl=http://localhost:33333;
  5. テーブルを表示および編集するには、テーブルを右クリックして Edit Data -> Grid をクリックします。

PowerBuilder コントロールで Outlook のデータ を使用

標準の PowerBuilder オブジェクトを使用して JDBC データソースに接続し、クエリを実行できます。以下の例では、Outlook のデータ を DataWindow に取得する方法を示します。以下のコードを open メソッドに追加できます。

SQLCA.DBMS = "JDBC"
SQLCA.AutoCommit = False
SQLCA.DBParm = "Driver='cdata.jdbc.api.APIDriver',URL='jdbc:api:Profile=C:\profiles\Outlook.apip;AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;TenantId=your_tenant_id;CallbackUrl=http://localhost:33333;";
CONNECT USING SQLCA;
dw_calendargroupcalendars.SetTransObject(SQLCA);
dw_calendargroupcalendars.Retrieve();

はじめる準備はできましたか?

API Driver で Outlook のライブデータに接続

Outlook に接続