DOORS DX

ベストなDXへの入り口が
見つかるメディア

Microsoft Fabric への移行:Azure SQL Database から レイクハウスへ

公開日
2025.03.27
更新日
2025.03.27

「Microsoft Fabric」の技術検証を基に、Microsoft Fabricの魅力や各種ポイントを解説していきます。

今回は Azure SQL Database から Microsoft Fabric へのデータ移行方法の 1 つをご紹介します。

とあるお客様より「既存の環境より手軽に分析したいため、Azure SQL Database から Microsoft Fabric へデータ移行を実施したい」というご相談がありました。
そのお客様は現状、直接 Azure SQL Database のデータを分析されており、その他の諸条件(現状の利用方法、データ量、環境を含めた移行難易度、等)を鑑みて、Microsoft Fabric のレイクハウスに移行してはいかがかとご提案しました。

今回ご紹介する内容は、公式ドキュメントの「移行: Azure Synapse Analytics 専用 SQL プールから Fabric へ」内にある「方法 3. DDL 移行 – コピー ウィザードの ForEach Copy アクティビティ」を応用した内容となります。
具体的には、Data Factory のコピーウィザードを使って、GUI 設定で ForEach Copy アクティビティを作成し、実行する手順を記載しています。

なお、上記に挙げた公式ドキュメントは Azure Synapse Analytics 専用 SQL プールが中心となっておりますが、移行における考えや手順については Azure SQL Database でも適用できる部分が多いので、Azure SQL Database から Microsoft Fabric へのデータ移行を検討されている方は参考にしてみると良いかと思います。

Data Factory のコピーウィザード

Microsoft Fabric のエクスペリエンスの 1 つである Data Factory のコピーウィザードを使用し、Azure SQL Database のテーブル/ビューを Fabric のレイクハウスに移行する手順について、Azure 側と Fabric 側に分けて順を追って解説します。

  • Azure 側の設定
  • Microsoft Fabric 側の設定

Azure 側の設定

まずは Azure 側の設定を行います。Azure 側の設定内容は 2 つあります。

  1. Azure SQL Database の準備と必要な設定
  2. Fabric 容量の準備

なお、検証した際の Azure 権限は「共同作成者」権限で実施しています。

Azure SQL Database の準備と必要な設定

移行元の Azure SQL Database を準備します。今回は検証なので、新規にサンプルデータベースを持った Azure SQL Database を作成しました。
サンプルデータベースの作成は、Azure SQL Database を作成する際に「追加設定」タブの「既存のデータを使用します」で「サンプル」を選択すれば OK です。

SQLデータベースの作成

「サンプル」を選択すると以下のデータベースを自動で作成してくれます。

Azure SQL Database のサーバー側ネットワーク設定

ここでのポイントは、Azure SQL Database のサーバー側ネットワーク設定です。

Azure SQL Database が動いているサーバー(SQL Server)の「セキュリティ」→「ネットワーク」より「Azure サービスおよびリソースにこのサーバーへのアクセスを許可する」にチェックを入れる必要があります(下図赤枠部分)。

チェックを入れない場合、Microsoft Fabric の Data Factory が Azure SQL Database にアクセスできず、コピーウィザードの実行が失敗してしまいます。

Azure SQL Database のサーバー側ネットワーク設定

Fabric 容量の準備

次に Azure 内に Fabric 容量を作成します。
Fabric 容量の作成については以下を参照ください。

参考:Azure SKU を購入する

Fabric 容量の作成は基本的に以下の設定のみなので、それほど難しくはないかと思います。

Fabric 容量の作成

Fabric 側の設定

Azure 側の設定が完了したら、Fabric 側の設定を行います。Fabric 側の設定内容は 2 つあります。

  1. ワークスペースの準備
  2. Data Factory の準備と必要な設定

なお、検証した際の Fabric 権限は「Fabric 管理者」権限で実施しています。
検証内でワークスペースを新規で作成したため、自動的に「ワークスペース管理者」の権限も所有した状態で実施しています。

ワークスペースの準備

Fabric 容量の作成については以下を参照ください。

参考:ワークスペースの作成

ここでのポイントは以下 2 点となります(下図赤枠部分参照)

  • 「ライセンスモード」に「ファブリック容量」を選択
  • 「キャパシティ」に「Fabric 容量の準備」で作成した Fabric 容量を指定
ワークスペースの作成

Data Factory の準備と必要な設定

ワークスペースを作成後、以下の順番で Data Factory のコピーウィザードを作成します。

  1. データパイプラインの作成
  2. コピーウィザードの設定
データパイプラインの作成

ワークスペースの「+新しい項目」より「Data pipeline」を選択し、新しいパイプラインに名前をつけて「作成」をクリックします。

Data Factory の準備と必要な設定
コピーウィザードの設定

パイプラインを作成後、「アクティビティ」タブ→「データコピー」→「コピーアシスタントを使用する」をクリックします。

コピーウィザードの設定

ここからコピーウィザードの設定を行います。
「データソースの選択」で「Azure SQL Database」を選択します。

コピーウィザードの設定

「Azure SQL Database の準備と必要な設定」で作成した Azure SQL Database の接続情報を入力して「次へ」をクリックします。

<入力項目>

カテゴリ入力項目
接続設定サーバーAzure SQL Database のサーバー名
データベースAzure SQL Database のデータベース名
接続の資格情報接続「新しい接続の作成」で OK
接続名任意で設定可能。
サーバーとデータベースを入力すると、デフォルトで以下のように自動入力される。
<サーバー>;<データベース>
データゲートウェイ「(なし)」で OK
認証の種類以下 3 つから選択。
基本:SQL 認証(ID とパスワード入力)
組織アカウント:ユーザーアカウント
サービスプリンシパル
暗号化された接続を使用するチェックを入れる
オンプレミスのデータゲートウェイまたは VNet データゲートウェイでこの接続を使用できるようにしますチェックを外す
データコピー データソースへの接続

「データソースへの接続」で、移行したいテーブル/ビューを選択して「次へ」をクリックします。
今回は「すべて選択」にチェックを入れました。

データコピー データソースへの接続

「データ変換先の選択」で「新しいファブリック項目」→「Lakehouse」を選択し、新しいレイクハウスに任意の名前をつけてレイクハウスを作成します。

今回はコピーウィザードの作成の流れでレイクハウスを作成しましたが、既存のレイクハウスがある場合は上部にある検索バーよりレイクハウスを検索・指定すれば OK です。

データコピー データソースへの接続
「データ変換先の選択」で「新しいファブリック項目」→「Lakehouse」

「データ変換先に接続」で Azure SQL Database とレイクハウスのデータ型をマッピングできます。各テーブル/ビューのマッピングを確認し「次へ」をクリックします。

今回はすべてデフォルトの設定にしました。

「データ変換先に接続」で Azure SQL Database とレイクハウスのデータ型をマッピング

レイクハウス側で選べるデータ型は限られているので注意が必要です。

<レイクハウスで設定できるデータ型>

<レイクハウスで設定できるデータ型>

「レビューと保存」で「データ転送をすぐに開始する」(デフォルト:オン)にチェックが入っていることを確認して、「保存と実行」をクリックします。

レビューと保存

「保存と実行」をクリックするとパイプラインの画面に戻り、ForEach アクティビティが作成されています。右側にパラメーターの画面が出ているので「OK」をクリックすると、Azure SQL Database からレイクハウスへのデータコピーが開始されます。

なお、右側のパラメーターの「値」には、「データ変換先に接続」で Azure SQL Database とレイクハウスのデータ型をマッピングした内容が JSON 形式で格納されています。

zure SQL Database からレイクハウスへのデータコピー

今回、Azure SQL Database のサンプルデータベースを使って検証をしていますが、データコピーを実行中に 1 件エラーが発生しました。エラーの内容は以下になります。

『Failure happened on ‘destination’ side. ErrorCode=DeltaInvalidCharacterInColumnName
,’Type=Microsoft.DataTransfer.Common.Shared.HybridDeliveryException,Message=Column name Database Version contains invalid characters. “,;{}()\n\t=” are not supported.,Source=Microsoft.DataTransfer.ClientLibrary,’』

どうやら Azure SQL Database のテーブルのカラム名が適切でないようです。

Azure SQL Database のサンプルデータベースを使って検証

Azure SQL Database の該当のカラム名を見てみましょう。エラーになっているのは「Database Version」というカラム名でした。エラーの内容とは直接的に合致しなさそうのですが、カラム名に半角スペースが入っているのが引っ掛かったのだと推察しました。

※データベースでテーブル名やフィールド名にスペースを使うことは、一般的には推奨されていないため。

エラー:Database Version

エラーになったテーブル以外は、レイクハウスのテーブルにコピーされています(赤枠部分が該当)。

レイクハウスのテーブル

なお、コピーウィザードで作成したアクティビティを再実行したい場合は、ForEach アクティビティ内にあるデータコピーアクティビティを選択して「宛先」タブ→「テーブルアクション」より追加か上書きを指定できます。

テーブルアクション

ミラーリングとの違い

Azure SQL Database のデータを Microsoft Fabric に移行すると聞いて、Microsoft Fabric の機能であるミラーリングを思い浮かべた方もいらっしゃるかもしれません。
確かに、Microsoft Fabric 内に物理的にデータを取りこむという点では、今回ご紹介したコピーウィザードもミラーリングも同じとなります。

コピーウィザードとミラーリングの違いは利用方法にあります。
コピーウィザードはデータ移行(1 回のみの)、定期的なデータコピーのいずれにも対応しています。
ミラーリングはニアリアルタイムでのデータ同期がメインの機能となっています。

ミラーリングも移行に使えないことはないのですが(※)、ミラーリングの設定には諸々の制約があるため、Microsoft Fabric へのデータ移行を実現したい場合はコピーウィザードの方がお勧めかもしれません。

(※)ミラーリングの設定を実施し、データを完全に同期させた後、ミラーリングの設定を解除することでデータ移行と同様のことを行うことは可能です。


まとめ

今回は Azure SQL Database から Microsoft Fabric へのデータ移行方法の 1 つとして、Data Factory のコピーウィザードを使用した方法をご紹介しました。
Azure SQL Database から Microsoft Fabric へ”単純にデータを移行するだけ”なら、思っていた以上に簡単にデータ移行ができることが分かったかと思います。

ただし、データ移行プロジェクトは通例”単純にデータを移行するだけ”ではありません。
データ移行に伴い、影響がある部分は意外と多いです。

<データ移行プロジェクトで必要なこと(抜粋)>

  • 業務影響、システム停止時間の有無
  • 移行方針
  • ETL や連携システムの切り替え
  • 切り戻し方法
  • 移行後の運用

データ移行後も業務が円滑に回ることを前提に、お客様の条件に応じたご提案が可能です。Microsoft Fabric への移行をお考えの方は弊社にご相談ください。


このページをシェアする

あなたにオススメの記事

株式会社ブレインパッドについて

2004年の創業以来、「データ活用の促進を通じて持続可能な未来をつくる」をミッションに掲げ、データの可能性をまっすぐに信じてきたブレインパッドは、データ活用を核としたDX実践経験により、あらゆる社会課題や業界、企業の課題解決に貢献してきました。 そのため、「DXの核心はデータ活用」にあり、日々蓄積されるデータをうまく活用し、データドリブン経営に舵を切ることであると私達は考えています。

メールマガジン

Mail Magazine