このクイック スタートでは、Visual Studio Code で Jupyter Notebook を使用して、ビジネスの分析情報をすばやく導き出します。 Python 用の mssql-python ドライバーを使用して SQL データベース に接続し、電子メールやレポートプレゼンテーションなどで使用できるように書式設定されたデータを読み取ります。
mssql-python ドライバーでは、Windows マシンへの外部依存関係は必要ありません。 ドライバーは、1 つの pip インストールで必要なすべてのものをインストールします。これにより、アップグレードとテストの時間がない他のスクリプトを中断することなく、新しいスクリプトに最新バージョンのドライバーを使用できます。
mssql-python のドキュメント | mssql-python ソース コード | Package (PyPi) | Visual Studio Code
[前提条件]
Python 3
Python をまだお持ちでない場合は、python ランタイムと Python Package Index (PyPI) パッケージ マネージャーを python.org からインストールします。
独自の環境を使用したくないですか? GitHub Codespaces を使用して devcontainer として開きます。
Visual Studio Code と次の拡張機能:
uvがまだない場合は、uvの手順に従ってhttps://docs.astral.sh/uv/getting-started/installation/をインストールします。Fabric の SQL Server、Azure SQL Database、または SQL データベースにある、
AdventureWorks2025サンプルスキーマと有効な接続文字列を備えたデータベース。オペレーティング システム固有の 1 回限りの前提条件をインストールします。
SQL データベースを作成する
このクイック スタートでは、Microsoft SQL Server の AdventureWorks2025 ライトウェイト スキーマ、Fabric の SQL データベース、または Azure SQL Database が必要です。
プロジェクトを作成してコードを実行する
- 新しいプロジェクトを作成する
- 依存関係の追加
- Visual Studio Code を起動する
- pyproject.toml を更新する
- 接続文字列を保存する
- Jupyter Notebook を作成する
- テーブルに結果を表示する
- グラフに結果を表示する
新しいプロジェクトを作成する
開発ディレクトリでコマンド プロンプトを開きます。 お持ちでない場合は、
python、scriptsなどの名前の新しいディレクトリを作成します。OneDrive 上のフォルダーを避け、同期によって仮想環境の管理が妨げられる可能性があります。-
uv init jupyter-notebook-qs cd jupyter-notebook-qs
依存関係を追加する
同じディレクトリに、 mssql-python、 python-dotenv、 rich、 pandas、および matplotlib パッケージをインストールします。 次に、 ipykernel と uv を開発依存関係として追加します。 VS Code では、ipykernelなどのコマンドを使用してノートブック セル内からuvを操作できるようにするには、uvと!uv add mssql_pythonが追加されている必要があります。
uv add mssql_python dotenv rich pandas matplotlib
uv add --dev ipykernel
uv add --dev uv
Visual Studio Code を起動します
同じディレクトリで、次のコマンドを実行します。
code .
pyproject.toml を更新する
pyproject.toml には、プロジェクトのメタデータが含まれています。
説明をよりわかりやすいものに更新します。
description = "A quick example using the mssql-python driver and Jupyter Notebooks."ファイルを保存して閉じます。
接続文字列を保存する
.gitignoreファイルを開き、.envファイルの除外を追加します。 ファイルは次の例のようになります。 完了したら、必ず保存して閉じてください。# Python-generated files __pycache__/ *.py[oc] build/ dist/ wheels/ *.egg-info # Virtual environments .venv # Connection strings and secrets .env現在のディレクトリに、
.envという名前の新しいファイルを作成します。.envファイル内に、SQL_CONNECTION_STRINGという名前の接続文字列のエントリを追加します。 ここでの例を実際の接続文字列の値に置き換えます。SQL_CONNECTION_STRING="Server=<server_name>;Database={<database_name>};Encrypt=yes;TrustServerCertificate=no;Authentication=ActiveDirectoryInteractive"ヒント
ここで使用される接続文字列は、接続先の SQL データベースの種類によって大きく異なります。 Fabric で Azure SQL Database または SQL データベースに接続する場合は、[接続文字列] タブから ODBC 接続文字列を使用します。シナリオによっては、認証の種類の調整が必要になる場合があります。 接続文字列とその構文の詳細については、 接続文字列の構文リファレンスを参照してください。
Jupyter Notebook を作成する
一覧から [ ファイル] を選択し、[ 新しいファイル ] と [Jupyter Notebook ] を選択します。 新しいノートブックが開きます。
[ ファイル]、[ 名前を付けて保存... ] の順に選択し、新しいノートブックに名前を付けます。
最初のセルに次のインポートを追加します。
from os import getenv from mssql_python import connect from dotenv import load_dotenv from rich.console import Console from rich.table import Table import pandas as pd import matplotlib.pyplot as pltノートブックの上部にある [+ マークダウン ] ボタンを使用して、新しいマークダウン セルを追加します。
新しいマークダウン セルに次のテキストを追加します。
## Define queries for use laterセル ツールバーで チェック マーク を選択するか、キーボード ショートカット
Ctrl+EnterまたはShift+Enterを使用してマークダウン セルをレンダリングします。ノートブックの上部にある [+ コード ] ボタンを使用して、新しいコード セルを追加します。
新しいコード セルに次のコードを追加します。
SQL_QUERY_ORDERS_BY_CUSTOMER = """ SELECT TOP 5 c.CustomerID, c.CompanyName, COUNT(soh.SalesOrderID) AS OrderCount FROM SalesLT.Customer AS c LEFT OUTER JOIN SalesLT.SalesOrderHeader AS soh ON c.CustomerID = soh.CustomerID GROUP BY c.CustomerID, c.CompanyName ORDER BY OrderCount DESC; """ SQL_QUERY_SPEND_BY_CATEGORY = """ select top 10 pc.Name as ProductCategory, SUM(sod.OrderQty * sod.UnitPrice) as Spend from SalesLT.SalesOrderDetail sod inner join SalesLt.SalesOrderHeader soh on sod.salesorderid = soh.salesorderid inner join SalesLt.Product p on sod.productid = p.productid inner join SalesLT.ProductCategory pc on p.ProductCategoryID = pc.ProductCategoryID GROUP BY pc.Name ORDER BY Spend; """
テーブルに結果を表示する
ノートブックの上部にある [+ マークダウン ] ボタンを使用して、新しいマークダウン セルを追加します。
新しいマークダウン セルに次のテキストを追加します。
## Print orders by customer and display in a tableセル ツールバーで チェック マーク を選択するか、キーボード ショートカット
Ctrl+EnterまたはShift+Enterを使用してマークダウン セルをレンダリングします。ノートブックの上部にある [+ コード ] ボタンを使用して、新しいコード セルを追加します。
新しいコード セルに次のコードを追加します。
load_dotenv() with connect(getenv("SQL_CONNECTION_STRING")) as conn: # type: ignore with conn.cursor() as cursor: cursor.execute(SQL_QUERY_ORDERS_BY_CUSTOMER) if cursor: table = Table(title="Orders by Customer") # https://rich.readthedocs.io/en/stable/appendix/colors.html table.add_column("Customer ID", style="bright_blue", justify="center") table.add_column("Company Name", style="bright_white", justify="left") table.add_column("Order Count", style="bold green", justify="right") records = cursor.fetchall() for r in records: table.add_row(f"{r.CustomerID}", f"{r.CompanyName}", f"{r.OrderCount}") Console().print(table)ヒント
macOS で Microsoft Entra Authentication を使用するには、Visual Studio Code の Azure Repos 拡張機能を使用するか、Azure
az login経由でを実行してサインインする必要があります。ノートブックの上部にある [ すべて実行 ] ボタンを使用して、ノートブックを実行します。
プロンプトが表示されたら 、jupyter-notebook-qs カーネルを選択します。
グラフに結果を表示する
最後のセルの出力を確認します。 3 つの列と 5 つの行を含むテーブルが表示されます。
ノートブックの上部にある [+ マークダウン ] ボタンを使用して、新しいマークダウン セルを追加します。
新しいマークダウン セルに次のテキストを追加します。
## Display spend by category in a horizontal bar chartセル ツールバーで チェック マーク を選択するか、キーボード ショートカット
Ctrl+EnterまたはShift+Enterを使用してマークダウン セルをレンダリングします。ノートブックの上部にある [+ コード ] ボタンを使用して、新しいコード セルを追加します。
新しいコード セルに次のコードを追加します。
with connect(getenv("SQL_CONNECTION_STRING")) as conn: # type: ignore data = pd.read_sql_query(SQL_QUERY_SPEND_BY_CATEGORY, conn) # Set the style - use print(plt.style.available) to see all options plt.style.use('seaborn-v0_8-notebook') plt.barh(data['ProductCategory'], data['Spend'])[セルの実行] ボタンまたは
Ctrl+Alt+Enterを使用してセルを実行します。結果を確認します。 このノートブックを自分のものにします。
次のステップ
その他の例については、 mssql-python ドライバーの GitHub リポジトリを参照して、アイデアの投稿や問題の報告を行います。