![](https://analytic-vba.com/wp/wp-content/uploads/2021/03/ポイント-1-644x562.jpg)
今回は、各種クエリに関する処理について解説します
解説する処理内容は全部で5つになります
最後の依存関係は前述の1.~4.全てに関わります
この回で解説する依存関係とは、データソースやクエリのマージ(結合)のことになります
順序は逆になりますが、今回の事例として使用するファイルを解説する意味もありますので、5.の依存関係から解説を行います
5.依存関係
今回使用するファイルは、過去の記事でも使用したファイルです
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-146.png)
この時には、商品台帳と売上台帳をマージして「売上金額クエリ」を作成し、売上金額を計算しました
では早速、「売上金額クエリ」の依存関係を見てみます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-147.png)
まず「売上金額クエリ」の上で右クリックして、Power Queryエディタ(以降、エディタ)を開きます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-141.png)
エディタが開いたら、表示タブをクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-142.png)
すると、上の画像右の「クエリの依存関係」をクリックできるようになります
下の画像が、「クエリの依存関係」をクリックした時に開く画面です
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-143-644x476.png)
上の図を見ると「売上金額クエリ」は①商品台帳クエリと②売上台帳クエリとマージしており、この2つのクエリに依存しているのが分かります
①と②についても、依存の状況は分かります
①商品台帳クエリ
このクエリは「e:\パワークエリ講座・・・」のフォルダにあるファイルからデータを取得しているのが分かります
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-144.png)
この 「e:\パワークエリ講座・・・」の上にカーソルを置くと更に詳細が分かります
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/Unlock-Query.gif)
②売上台帳クエリ
売上台帳クエリは①の商品台帳クエリと違い、売上金額クエリが存在するファイル内からデータを取得していることが分かります
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-145.png)
上の関係図にはないですが、売上台帳クエリは現在ブック内の「売上台帳テーブル」からデータを取得しています
ちなみに上の図に、「読み込まれていません」とありますが、こちらはクエリの読込先が「接続のみ」になっていることを表します
今回、事例とするクエリのことも解説したところで、前述の1.~4.についても解説を行って行きます
1.クエリを別ファイルにコピー
まず、商品台帳クエリを別ファイルにコピーします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-148.png)
商品台帳クエリ上で右クリックし、「コピー」をクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-149.png)
そして、別ファイルで貼り付けます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-150.png)
では、他2つのクエリに依存している「売上金額クエリ」を別ファイルにコピーしてみます
すると下の図の通り、依存している2つのクエリも同時にコピーされます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-151.png)
売上台帳クエリは「現在のブック」内のテーブルを取得元にしています
別ファイルには、もちろん「売上台帳クエリ」の取得元になるテーブルはありませんので、売上台帳クエリはエラーになります
そして、「売上台帳クエリ」に依存している「売上金額クエリ」もエラーになります
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-152.png)
2.クエリのバックアップ、復元
では冒頭で紹介した、「事例として使用するファイル内」にある「商品台帳クエリ」をバックアップします
次の図の「接続ファイルのエクスポート」をクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-153.png)
するとクエリのバックアップ先を指定する画面が出ますので、そちらに保存処理を行います
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-154.png)
バックアップの復元については、以下の画面で行います
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-155.png)
こちらは、4.のクエリの一括削除を行った後に、追加で解説を行います
3.クエリの数が多い場合のグループ化
では、冒頭の事例として解説したファイルに戻ります
Ctrlキーを押しながら「商品台帳クエリ」「売上台帳クエリ」を選択します
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-156.png)
そして、右クリックすると「グループ作成」を指定できます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-157.png)
作成するグループには「名前」をつけます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-158.png)
名前をOKボタンを押すと、「作成したグループ名」のグループと、それ以外のグループに分かれます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/Make-Group.gif)
作成したグループを解除する時には、下の図の「グループ解除」をクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-159.png)
クエリをグループ間で移動させたい時には、移動させるクエリを右クリックし、次の画像の黄色の箇所をクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-160.png)
4.クエリの一括削除
引き続き3.で使用したファイルにて、クエリの削除を行います
「商品台帳クエリ」上にカーソルを置いて右クリックし、更に削除をクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-172.png)
すると、「商品台帳クエリ」は「売上金額クエリ」に依存されているため、下の画像のようなメッセージが出て削除ができません
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-161.png)
一方で、Ctrlキーを使用して、全てのクエリを指定して削除をすると「依存関係」自体も削除されるため、一括で削除されます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/Delete-All.gif)
なおクエリが削除されて後も、クエリからシートに読込まれていたテーブルデータは削除されません
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-173.png)
ちなみにCtrlキーを使用する方法の他にも、一括でクエリを削除する方法があります
まず「ファイルタブ」をクリックした後、情報タブをクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-174.png)
更に「問題のチェック」の右下にある▼マークをクリックした後に、「ドキュメント検査」をクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-163.png)
次に「ドキュメントの検査」が開くので、画面下の「検査」ボタンをクリックします
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-164.png)
クエリがファイル内にあると、下の図のように「カスタムXMLデータが見つかりました。」とメッセージが出ます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-165.png)
「すべて削除」をクリックすると、すべてのクエリがファイルから削除されます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-166.png)
ファイル内のクエリが全て削除されたところで、2.でバックアップを取ったクエリを復元してみます
クエリの復元は、前述のようにデータタブにある「既存の接続」から行います
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/Recovery.gif)
「既存の接続」をクリックした後に開いた画面の左下に「参照」があります
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-168.png)
上の図の「参照」をクリックすると、バックアップしたクエリを指定できるようになります
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-169.png)
クエリを復元する時には、下の図のように「データのインポート」画面が開きますので、こちらで読込先を指定します
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-170.png)
<まとめ>
今回は、クエリの「依存関係」を含め、全部で5つの処理を解説しました
1.~4.の処理を行うに当たっては、必ず5.の「依存関係」は事前に確認しておきましょう
尚、1.のクエリのコピーについては、過去の記事で紹介した「複製」とはきちんと区別しておきましょう
クエリの複製の場合には、他ファイルにはコピーはできません
そして、複製の場合には1.のコピーとは違い「依存関係」があるクエリはコピーされません
ちなみに、1.のクエリのコピーした内容をテキストボックスに貼り付けると、詳細エディタの内容がコピーされます
![](https://analytic-vba.com/wp/wp-content/uploads/2021/02/image-171.png)
今回は以上です
次回は、重要なデータ成型の仕方の一つ「文字列の抽出」について解説します
長文に最後までお付き合い頂き誠にありがとうございました
![にほんブログ村 資格ブログ ビジネススキルへ](http://qualification.blogmura.com/businessskill/img/businessskill88_31.gif)
![にほんブログ村 IT技術ブログ VBAへ](http://it.blogmura.com/vba/img/vba88_31.gif)