製品をチェック

製品の詳細・30日間の無償トライアルはこちら

CData Sync

MySQL へのZuora データのETL/ELT パイプラインを作ってデータを統合する方法

データパイプラインツールのCData Sync を使って、Zuora データのMySQL へのETL/ELT パイプラインをノーコードで作成してデータを統合する方法を解説します。

宮本航太
プロダクトスペシャリスト

最終更新日:2024-01-19
zuora ロゴ

CData

sync ロゴ画像
Oracle Database ロゴ

こんにちは!プロダクトスペシャリストの宮本です。

データ分析基盤DB へのZuora データの取り込みのニーズが高まっています。CData Sync は、数百のSaaS / DB のデータをOracle をはじめとする各種DB / データウェアハウスにノーコードで統合・レプリケーション(複製)が可能なデータパイプラインツールです。本記事では、Zuora データをCData Sync を使ってOracle に統合するデータパイプラインを作っていきます。Oracle は、オンプレミスのOracle のほかAWS RDS やGoogle Cloud SQL などクラウド上のOracle にもレプリケーションが可能です。エンタープライズからSME までのETL(抽出、変換・加工、ロード)、ELT のニーズに応えます。

CData Sync とは?

CData Sync は、レポーティング、アナリティクス、機械学習、AI などで使えるよう、社内のデータを一か所に統合して管理できるデータ基盤をノーコードで構築できるETL/ELT ツールで、以下の特徴を持っています。

  1. Zuora をはじめとする数百種類のSaaS / DB データに対応
  2. Oracle など多くのRDB、データレイク、データストア、データウェアハウスに同期可能
  3. 業務データのデータ分析基盤へのETL / ELT 機能に特化し、極限まで設定操作をシンプルに
  4. 主要なSaaS データの差分更新やCDC(Change Data Capture、変更データキャプチャ)のサポート
  5. フレキシブルなSQL での取得データの操作

CData Sync では、1.データソースとしてZuora の接続を設定、2.同期先としてOracle の接続を設定、3.Zuora からOracle へのレプリケーションジョブの作成、という3つのステップだけでレプリケーション処理を作成可能です。以下に具体的な設定手順を説明します。

1.データソースとしてZuora の接続を設定

まずはじめに、CData Sync のブラウザ管理コンソールにログインします。CData Sync のインストールをまだ行っていない方は本記事の製品リンクからCData Sync をクリックして、30日の無償トライアルとしてCData Sync をインストールしてください。インストール後にCData Sync が起動して、ブラウザ設定画面が開きます。

それでは、データソース側にZuora を設定していきましょう。左の[接続]タブをクリックします。

  1. [+接続の追加]ボタンをクリックします。 コネクションの追加。
  2. [データソース]タブを選択して、リスト表示されるデータソースを選ぶか、検索バーにデータソース名を入力して、Zuora を見つけます。
  3. Zuora の右側の[→]をクリックして、Zuora アカウントへの接続画面を開きます。もし、Zuora のコネクタがデフォルトでCData Sync にインストールされていない場合には、ダウンロードアイコン(コネクタのアップロードアイコン)をクリックし、[ダウンロード]をクリックすると、CData Sync にコネクタがインストールされます。 データソースの追加。
  4. 接続プロパティにZuora に接続するアカウント情報を入力をします。

    Zuora はユーザー認証にOAuth 標準を使用しています。OAuth 認証ついて詳しくは、オンラインヘルプドキュメントを参照してください。

    Tenant プロパティの設定

    プロバイダへの有効な接続を作成するには、アカウントの設定と合致するテナント値を1つ選択する必要があります。以下は、利用可能なオプションのリストです。

    • USProduction:リクエストはhttps://rest.zuora.com に送信されます。
    • USAPISandbox:リクエストはhttps://rest.apisandbox.zuora.com に送信されます。
    • USPerformanceTest:リクエストはhttps://rest.pt1.zuora.com に送信されます。
    • EUProduction:リクエストはhttps://rest.eu.zuora.com に送信されます。
    • EUSandbox:リクエストはhttps://rest.sandbox.eu.zuora.com に送信されます。

    デフォルトではUSProduction テナントを使用します。

    Zuora サービスの選択

    データクエリとAQuA API の2つのZuora サービスを使用します。デフォルトでは、ZuoraServiceAQuADataExport に設定されています。

    DataQuery

    データクエリ機能は、非同期の読み取り専用SQL クエリを実行することで、Zuora テナントからのデータのエクスポートを実現します。 このサービスは、素早く軽量なSQL クエリでの使用を推奨します。

    制限

    • フィルタ適用後の、テーブルごとの入力レコードの最大数: 1,000,000
    • 出力レコードの最大数: 100,000
    • テナントごとの、実行用に送信される同時クエリの最大数: 5
    • テナントごとの、同時クエリの制限に達した後に実行用に送信され、キューに追加されるクエリの最大数: 10
    • 1時間単位での、各クエリの最大処理時間: 1
    • GB 単位での、各クエリに割り当てられるメモリの最大サイズ: 2
    • Index Join を使用する際のインデックスの最大値。言い換えれば、Index Join を使用する際にWHERE 句で使われる一意の値に基づいた、左のテーブルから返されるレコードの最大数: 20.000

    AQuADataExport

    AQuA API のエクスポートは、すべてのオブジェクト(テーブル)のすべてのレコードをエクスポートするように設計されています。AQuA のクエリジョブには以下の制限があります。

    制限

    • AQuA のジョブ内のクエリが8時間以上実行されている場合、ジョブは自動的に停止されます。
    • 停止されたAQuA のジョブは3回再試行可能で、その後失敗として返されます。
    データソースの追加。
  5. [作成およびテスト]をクリックして、正しくZuora に接続できているかをテストして保存します。これでレプリケーションのデータソースとしてZuora への接続が設定されました。

2.同期先としてOracle の接続を設定

次に、Zuora データを書き込む先(=同期先)として、Oracle を設定します。同じく[接続]タブを開きます。

  • [+接続の追加]ボタンをクリックします。
  • [同期先]タブを選択して、リスト表示されるデータソースを選ぶか、検索バーにデータソース名を入力して、Oracle を見つけます。
  • Oracle の右側の[→]をクリックして、Oracle データベースへの接続画面を開きます。もし、Oracle のコネクタがデフォルトでCData Sync にインストールされていない場合には、ダウンロードアイコン(コネクタのアップロードアイコン)をクリックし、[ダウンロード]をクリックすると、CData Sync にコネクタがインストールされます。 Oracle を同期先として設定。
  • 必要な接続プロパティを入力します。Oracle に接続するためには、Oracle Database Client が必要です。Instant Client では不可です。Oracle Database Client のダウンロード時には、アプリケーションのbit と一致するものをダウンロードします。インストール時にはRuntime もしくはAdministrator インストールタイプを選択します。

    Oracle データベースへの接続に次を設定します:

    • Server: Oracle データベースのホスト名、もしくはサーバーのIP あどれす。
    • Port: Oracle データベースをホストしているサーバーに接続するポート名。
    • User: Oracle データベースに認証するuser ID。
    • Password: Oracle データベースに認証するpassword。
    • SID: Oracle データベースのサービス名。

  • [作成およびテスト]をクリックして、正しく接続できているかをテストします 同期先接続のテスト
  • これで同期先としてOracle を設定できました。CData Sync では、Oracle のデータベース名を指定するだけで、同期するZuora に併せたテーブルスキーマを自動的にCREATE TABLE してくれます。同期データに合わせたテーブルを事前に作成するなどの面倒な手順は必要ありません。もちろん、既存テーブルにマッピングを行いデータ同期を行うことも可能です。
  • 3.Zuora からOracle へのレプリケーションジョブの作成

    CData Sync では、レプリケーションをジョブ単位で設定します。ジョブは、Zuora からOracle という単位で設定し、複数のテーブルを含むことができます。レプリケーションジョブ設定には、[ジョブ]タブに進み、[+ジョブを追加]ボタンをクリックします。 ジョブの追加Salesforce の例)。

    [ジョブを追加]画面が開き、以下を入力します:

    1. 名前:ジョブの名前
    2. データソース:ドロップダウンリストから先に設定したZuora を選択
    3. 同期先:先に設定したOracle を選択
    データソースの設定Salesforce の例)。

    すべてのオブジェクトをレプリケーションする場合

    Zuora のすべてのオブジェクト / テーブルをレプリケーションするには、[種類]セクションで[すべて同期]を選択して、[ジョブを追加]ボタンで確定します。

    作成したジョブ画面で、右上の[▷実行]ボタンをクリックするだけで、全Zuora テーブルのOracle への同期を行うことができます。

    オブジェクトを選択してレプリケーションする場合

    Zuora から特定のオブジェクト / テーブルを選択してレプリケーションを行うことが可能です。[種類]セクションでは、[標準(個別設定)]を選んでください。

    次に[ジョブ]画面で、[タスク]タブをクリックし、[タスクを追加]ボタンをクリックします。 ジョブへのタスク追加Salesforce の例)。

    するとCData Sync で利用可能なオブジェクト / テーブルのリストが表示されるので、レプリケーションを行うオブジェクトにチェックを付けます(複数選択可)。[ジョブを追加]ボタンで確定します。

    タスク選択(Salesforce の例)。

    作成したジョブ画面で、[▷実行]ボタンをクリックして(もしくは各タスク毎の実行ボタンを押して)、レプリケーションジョブを実行します。 作成したジョブの実行(Salesforce の例)。

    このようにとても簡単にZuora からOracle への同期を行うことができました。

    CData Sync の主要な機能を試してみる:スケジューリング・差分更新・ETL/ELT

    ジョブのスケジュール起動設定

    CData Sync では、同期ジョブを1日に1回や15分に1回などのスケジュール起動をすることができます。ジョブ画面の[概要]タブから[スケジュール]パネルを選び、[⚙設定]ボタンをクリックします。[間隔]と同期時間の[毎時何分]を設定し、[保存]を押して設定を完了します。これでCData Sync が同期ジョブをスケジュール実行してくれます。ユーザーはダッシュボードで同期ジョブの状態をチェックするだけです。 スケジュール実行設定。

    差分更新

    CData Sync では、主要なデータソースでは、差分更新が可能です。差分更新では、最後のジョブ実行時からデータソース側でデータの追加・変更があったデータだけを同期するので、レプリケーションのクエリ・通信のコストを圧倒的に抑えることが可能です。

    差分更新を有効化するには、ジョブの[概要]タブから「差分更新」パネルを選び、[⚙設定]ボタンをクリックします。[開始日]と[レプリケーション間隔]を設定して、[保存]します。

    SQL での取得データのカスタマイズ

    CData Sync は、デフォルトではZuora のオブジェクト / テーブルをそのままOracle に複製しますが、ここにSQL、またはdbt 連携でのETL/ELT 処理を組み込むことができます。テーブルカラムが多すぎる場合や、データ管理の観点から一部のカラムだけをレプリケーションしたり、さらにデータの絞り込み(フィルタリング)をしたデータだけをレプリケーションすることが可能です。

    ジョブの[概要]タブ、[タスク]タブへと進みます。選択されたタスク(テーブル)の[▶]の左側のメニューをクリックし、[編集]を選びます。タスクの編集画面が開きます。

    UI からカラムを選択する場合には、[カラム]タブから[マッピング編集]をクリックします。レプリケーションで使用しないカラムからチェックを外します。

    SQL を記述して、フィルタリングなどのカスタマイズを行うには、[クエリ]タブをクリックし、REPLICATE [テーブル名]の後に標準SQL でフィルタリングを行います。 レプリケーションのカスタマイズ設定。

    Zuora からOracle へのデータ同期には、ぜひCData Sync をご利用ください

    このようにノーコードで簡単にZuora データをOracle にレプリケーションできます。データ分析、AI やノーコードツールからのデータ利用などさまざまな用途でCData Sync をご利用いただけます。30日の無償トライアルで、シンプルでパワフルなデータパイプラインを体感してください。

    日本のユーザー向けにCData Sync は、UI の日本語化、ドキュメントの日本語化、日本語でのテクニカルサポートを提供しています。

    CData Sync の 導入事例を併せてご覧ください。

    関連コンテンツ

    トライアル・お問い合わせ

    30日間無償トライアルで、CData のリアルタイムデータ連携をフルにお試しいただけます。記事や製品についてのご質問があればお気軽にお問い合わせください。