クイック スタート:SSMS を使用して Azure SQL Database または Azure SQL Managed Instance に接続してクエリを実行する
適用対象: Azure SQL データベース Azure SQL Managed Instance
このクイックスタートでは、SQL Server Management Studio (SSMS) を使用して Azure SQL Database または Azure SQL Managed Instance に接続し、クエリを実行する方法について説明します。
前提条件
このクイックスタートを完了するには、次のアイテムが必要です。
Azure SQL データベース、Azure SQL Managed Instance、またはAzure VM の SQL Server のデータベース。 次のいずれかのクイックスタートを使用して、リソースを作成し、構成できます。
アクション SQL Database SQL Managed Instance Azure VM 上の SQL Server 作成 ポータル ポータル ポータル CLI CLI PowerShell PowerShell PowerShell 構成 サーバーレベルの IP ファイアウォール規則
Microsoft Entra 認証1VM からの接続
オンサイトからの接続
Microsoft Entra 認証1SQL Server への接続
Microsoft Entra 認証1サンプル データベース AdventureWorksLT サンプル GitHub の BACPAC ファイルから Adventure Works を復元またはインポートする GitHub の BACPAC ファイルから Adventure Works を復元またはインポートする または Wide World Importers を復元する または Wide World Importers を復元する
1 このチュートリアルでは Microsoft Entra 多要素認証 (MFA) を使用します。これには、リソースに対して Microsoft Entra 管理者を構成する必要があります。 リソースに対して Microsoft Entra 認証を構成していない場合は、代わりに SQL Server 認証を使用できますが、安全性は低くなります。
重要
この記事のスクリプトは、Adventure Works データベースを使用するように記述されています。 マネージド インスタンスの場合は、Adventure Works データベースをインスタンス データベースにインポートするか、Wide World Importers データベースを使用するようにこの記事のスクリプトを修正する必要があります。
SSMS をインストールせずにアドホック クエリを Azure SQL データベースで実行する場合は、Azure portal のクエリ エディターを使って、データベースのクエリを実行します。
サーバーの接続情報を取得する
自分のリソースに接続するために必要な接続情報を取得します。 このクイックスタートを完了するには、完全修飾サーバー名 (Azure SQL データベース用) またはホスト名 (Azure SQL Managed Instance 用)、データベース名、およびログイン情報が必要になります。
Azure portal にサインインします。
クエリを実行するデータベースまたはマネージド インスタンスに移動します。
[概要] ページで、SQL Database 内のデータベースの場合は [サーバー名] の横の完全修飾サーバー名を確認し、SQL マネージド インスタンスまたは VM 上の SQL Server インスタンスの場合は [ホスト] の横の完全修飾サーバー名 (または IP アドレス) を確認します。 サーバー名またはホスト名をコピーするには、名前をポイントして [コピー] アイコンを選択します。
重要
- Azure VM 上の SQL Server の接続情報については、「SQL Server に接続する」を参照してください
- サーバーは、ポート 1433 でリッスンしています。 企業のファイアウォールの背後からサーバーに接続するには、そのファイアウォールでこのポートが開かれている必要があります。
データベースに接続する
SQL Server Management Studio (SSMS) でデータベースに接続します。
SSMS を開きます。
[サーバーに接続] ダイアログ ボックスが表示されます。 [ログイン] タブには、次の情報を入力します。
設定 推奨値 詳細 サーバーの種類 データベース エンジン [データベース エンジン] (通常は既定のオプションです) を選択します。 サーバー名 完全修飾サーバー名 ご利用の Azure SQL データベース サーバ名、または Azure SQL Managed Instance のホスト名を入力します。 認証 Microsoft Entra MFA/SQL Server 認証 このクイック スタートでは、推奨される Microsoft Entra 多要素認証を使用しますが その他の 認証オプション を使用できます。 Login サーバー アカウントのユーザー ID サーバーを作成するために使用するサーバー アカウントのユーザー ID。 Microsoft Entra MFA を選択した場合、ログインは必要ありません。 パスワード サーバー アカウントのパスワード サーバーを作成するために使用するサーバー アカウントのパスワード。 Microsoft Entra MFA を選択した場合、パスワードは必要ありません。 暗号化 Strict (SQL Server 2022 とAzure SQL) SQL Server Management Studio 20 以降では、Azure SQL リソースに接続するには Strict が必要です。 サーバー証明書を信頼する [Trust Server Certificate] サーバー証明書の検証をバイパスするには、このオプションをオンにします。 既定値は False (チェックなし) であり、信頼された証明書を使用してセキュリティを強化します。 [厳格な 暗号化] を選択すると、このオプションが既定で選択されます。 証明書のホスト名 サーバーのホスト名 このオプションで指定された値は、サーバー証明書で予期される、異なる CN または SAN を指定するために使用されます。 [サーバーへの接続] ダイアログ ボックスで、[接続プロパティ] タブを選択します。
[データベースへの接続] ドロップダウン メニューで、mySampleDatabase を選択します。 「前提条件」セクションのクイックスタートを完了すると、mySampleDatabase という名前の AdventureWorksLT データベースが作成されます。 AdventureWorks データベースの作業コピーの名前が mySampleDatabase と異なっている場合は、代わりにそれを選択します。
[接続] を選択します。 オブジェクト エクスプローラー ウィンドウが開きます。
データベースのオブジェクトを表示するには、 [データベース] を展開してから、自分のデータベース ノードを展開します。
クエリ データ
次の SELECT Transact-SQL のコードを実行して、カテゴリごとに上位 20 個の製品を照会します。
オブジェクト エクスプローラーで mySampleDatabase を右クリックし、 [新しいクエリ] を選択します。 データベースに接続された新しいクエリ ウィンドウが開きます。
クエリ ウィンドウに、次の SQL クエリを貼り付けます。
SELECT pc.Name AS CategoryName, p.name AS ProductName FROM [SalesLT].[ProductCategory] AS pc INNER JOIN [SalesLT].[Product] AS p ON pc.productcategoryid = p.productcategoryid;
ツールバーで、 [実行] を選択してクエリを実行し、
Product
テーブルおよびProductCategory
テーブルからデータを取得します。
データの挿入
次の INSERT Transact-SQL のコードを実行して、SalesLT.Product
テーブルに新しい製品を作成します。
前のクエリを次のクエリに置き換えます。
INSERT INTO [SalesLT].[Product] ([Name], [ProductNumber], [Color], [ProductCategoryID], [StandardCost], [ListPrice], [SellStartDate]) VALUES ('myNewProduct', 123456789, 'NewColor', 1, 100, 100, GETDATE());
[実行] を選択して、新しい行を
Product
テーブルに挿入します。 メッセージ ペインに、 (1 行処理されました) と表示されます。
結果を表示する
前のクエリを次のクエリに置き換えます。
SELECT * FROM [SalesLT].[Product] WHERE Name = 'myNewProduct';
[実行] を選択します。 次の結果が表示されます。
データの更新
次の UPDATE Transact-SQL コードを実行して、新しい製品を変更します。
上記のクエリを、前に作成した新しいレコードを返す次のクエリに置き換えます。
UPDATE [SalesLT].[Product] SET [ListPrice] = 125 WHERE Name = 'myNewProduct';
[実行] を選択して、
Product
テーブルの指定した行を更新します。 メッセージ ペインに、 (1 行処理されました) と表示されます。
データの削除
次の DELETE Transact-SQL コードを実行して、新しい製品を削除します。
前のクエリを次のクエリに置き換えます。
DELETE [SalesLT].[Product] WHERE Name = 'myNewProduct';
[実行] を選択して、
Product
テーブルの指定した行を削除します。 メッセージ ペインに、 (1 行処理されました) と表示されます。
認証オプション
このクイックスタートでは Microsoft Entra MFA を使用しますが、次のような他の認証オプションを使用できます。
- デフォルト: 既定のオプションは、パスワードレスで非対話型の Microsoft Entra 認証モードを使用して接続するときに使用できます。
- Microsoft Entra 多要素認証: 認証に対話型プロンプトを使用します。
- Azure SQL 用の Microsoft Entra でのマネージド ID: システム割り当てマネージド ID (SMI) とユーザー割り当てマネージド ID (UMI) の 2 種類のマネージド ID がサポートされています。 マネージド ID を使用して SSMS から任意の SQL 製品に接続する場合は、SSMS を Azure VM にインストールします。 SSMS は、そのマネージド ID のトークンを要求するためのアクセス権を持つ Azure コンテキスト内にある必要があります。 SQL 製品には、そのマネージド ID のプリンシパルが必要です。 「Windows VM のシステム割り当てマネージド ID を使用して Azure SQL にアクセスする」を参照してくだい。
- Microsoft Entra サービス プリンシパル: サービス プリンシパルを使用して、アプリケーション クライアント ID とシークレットを使用して、SSMS から SQL 製品に対する認証を行います。
- Microsoft Entra パスワード: Microsoft Entra ユーザー名とパスワードを使用して SQL 製品に接続します。
- Microsoft Entra 統合: 現在の Windows ユーザーの資格情報を使用して SQL 製品に接続します。
- SQL Server 認証: SQL Server ログインとパスワードを使用して SQL 製品に接続します。 このオプションは、Microsoft Entra 認証よりも安全性が低くなります。
関連するコンテンツ
- SQL Server Management Studio
- Azure SQL データベース用 Azure portal クエリ エディター
- クイックスタート: Visual Studio Code を使用して Azure SQL データベースまたは Azure SQL Managed Instance に接続してクエリを実行する
- クイックスタート: Visual Studio で .NET と C# を使用してデータベースに接続してクエリを実行する
- クイックスタート: PHP を使用して Azure SQL データベースまたは Azure SQL Managed Instance のデータベースにクエリの実行
- クイック スタート: Node.js を使用して Azure SQL データベースまたは Azure SQL Managed Instance 内のデータベースに対してクエリを実行する
- Azure SQL Database で Java と JDBC を使用する
- クイックスタート: Python を使用して Azure SQL Database または Azure SQL Managed Instance のデータベースに対してクエリを実行する
- クイック スタート: Ruby を使用して Azure SQL データベースまたは Azure SQL Managed Instance のデータベースに対してクエリを実行する