LINQPad でCosmos DB のデータを操作する方法
CData ADO.NET Provider for CosmosDB は、LINQ やEntity Framework などの標準のADO.NET インターフェースを使ってCosmos DB の操作を実現します。この記事では、LINQPad から接続してLINQ クエリを実行する方法を説明します。
必要なもの
本記事の手順を実行してLINQPad からCosmos DB に接続するには、以下の3つの製品が必要になります。
- Cosmos DB の環境
- LINQPad
- CData ADO.NET Provider for CosmosDB。右側のサイドバーから30日間無償トライアルがダウンロードできます
データモデルの作成
CData ADO.NET Provider for CosmosDB およびLINQPad をダウンロード・インストールしたら、Visual Studio で新しいクラスライブラリプロジェクトを作成します。
ADO.NET Provider の利用に必要となるEF 6を設定する方法については、ヘルプドキュメントを参照してください。
プロジェクトを右クリックし、[追加]→[新しい項目]→[ADO.NET Entity Data Model]をクリックします。ダイアログが表示されたら、データベースから[Code First]を選択します。 [New Connection]をクリックして、表示されたウィザードで接続文字列オプションを指定します。

- AccountEndpoint:この値は、Cosmos DB アカウントの「Keys」ブレードからのCosmos DB アカウントURL に設定してください。
- AccountKey:Azure ポータルで、Cosmos DB サービスに移動してAzure Cosmos DB アカウントを選択します。リソースメニューから、 「Keys」ページに移動します。「PRIMARY KEY」値を見つけ、Token をこの値に設定します。
希望するテーブルおよびビューを選択して[Finish]をクリックし、データモデルを作成します。

- プロジェクトをビルドします。生成されたファイルを使ってLINQPad でCosmos DB 接続を作成できます。
CosmosDB 接続プロパティの取得・設定方法
SQL API を使ってCosmos DB アカウントに接続するために必要な接続文字列を取得するには、Azure Portal にログインして「Azure Cosmos DB」を選択し、自分のアカウントを選択します。「Settings」セクションで、「Connection String」をクリックして次の値を設定します。
一般的な接続文字列は次のとおりです。
AccountEndpoint=myAccountEndpoint;AccountKey=myAccountKey;
LINQPad でCosmos DB のデータに接続
必要な接続プロパティを取得してデータモデルアセンブリを作成したら、以下の手順に従ってLINQPad でデータモデルを使いはじめましょう。
LINQPad を開き[接続の追加]をクリックします。

[Use a typed data context from your own assembly]オプションを選択します。
[Entity Framework DbContext]を選択します。
![下部のフィールドから[Entity Framework DbContext]を選択](../articles/ado-linqpad-qb-6.png)
[Path to Custom Assembly]ボックスの横にある[参照]をクリックして、プロジェクトフォルダを参照します。bin フォルダの下の.dll または.exe を参照します。
- DbContext の名前を選択します。
- 接続文字列をApp.Config に保存した場合は、App.Config へのパスを指定します。
これでLINQPad 経由でCosmos DB にクエリできます。サポートされたLINQ クエリの例は、ヘルプドキュメントの「LINQ およびEntity Framework」を参照してください。