Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Neste início rápido, você usará o Jupyter Notebook no Visual Studio Code para derivar rapidamente insights de negócios. Você usa o mssql-python driver do Python para se conectar ao banco de dados SQL e ler os dados formatados para uso em emails, apresentações de relatórios etc.
O mssql-python driver não requer nenhuma dependência externa em computadores Windows. O driver instala tudo o que precisa com uma única pip instalação, permitindo que você use a versão mais recente do driver para novos scripts sem quebrar outros scripts que você não tem tempo para atualizar e testar.
Documentação mssql-python | Código-fonte mssql-python | Pacote (PyPi) | Visual Studio Code
Pré-requisitos
Python 3
Se você ainda não tiver o Python, instale o runtime do Python e o gerenciador de pacotes PyPI (Python Package Index) do python.org.
Prefere não utilizar o seu próprio ambiente? Abra como um devcontainer usando codespaces do GitHub.
Visual Studio Code com as seguintes extensões:
Se você ainda não tiver
uv, instaleuvseguindo as instruções de https://docs.astral.sh/uv/getting-started/installation/.Um banco de dados no SQL Server, no Banco de Dados SQL do Azure ou no Banco de Dados SQL no Fabric com o
AdventureWorks2025esquema de exemplo e uma cadeia de conexão válida.Instale pré-requisitos específicos do sistema operacional uma vez.
Criar um banco de dados SQL
Este início rápido requer o esquema AdventureWorks2025 Lightweight , no Microsoft SQL Server, no banco de dados SQL no Fabric ou no Banco de Dados SQL do Azure.
Criar o projeto e executar o código
- Criar um novo projeto
- Adicionar dependências
- Iniciar Visual Studio Code
- Atualizar pyproject.toml
- Salvar a cadeia de conexão
- Criar um Jupyter Notebook
- Exibir resultados em uma tabela
- Exibir resultados em um gráfico
Criar um novo projeto
Abra um prompt de comando no diretório de desenvolvimento. Se você não tiver um, crie um novo diretório chamado
python,scriptsetc. Evite pastas em seu OneDrive, a sincronização pode interferir no gerenciamento do seu ambiente virtual.Crie um novo projeto com
uv.uv init jupyter-notebook-qs cd jupyter-notebook-qs
Adicionar dependências
No mesmo diretório, instale os pacotes mssql-python, python-dotenv, rich, pandas e matplotlib. Em seguida, adicione ipykernel e uv como dependências de desenvolvimento. O VS Code requer que ipykernel e uv sejam adicionados para poder interagir com uv dentro das células do seu notebook usando comandos como !uv add mssql_python.
uv add mssql_python dotenv rich pandas matplotlib
uv add --dev ipykernel
uv add --dev uv
Iniciar o Visual Studio Code
No mesmo diretório, execute o comando a seguir.
code .
Atualizar pyproject.toml
O pyproject.toml contém os metadados do projeto.
Atualize a descrição para ser mais descritiva.
description = "A quick example using the mssql-python driver and Jupyter Notebooks."Salve e feche o arquivo.
Salvar a cadeia de conexão
Abra o
.gitignorearquivo e adicione uma exclusão para.envarquivos. Seu arquivo deve ser semelhante a este exemplo. Salve-o e feche-o quando terminar.# Python-generated files __pycache__/ *.py[oc] build/ dist/ wheels/ *.egg-info # Virtual environments .venv # Connection strings and secrets .envNo diretório atual, crie um novo arquivo chamado
.env.No arquivo
.env, adicione uma entrada para sua string de conexão chamadaSQL_CONNECTION_STRING. Substitua o exemplo aqui pelo valor real da cadeia de conexão.SQL_CONNECTION_STRING="Server=<server_name>;Database={<database_name>};Encrypt=yes;TrustServerCertificate=no;Authentication=ActiveDirectoryInteractive"Dica
A cadeia de conexão usada aqui depende em grande parte do tipo de banco de dados SQL ao qual você está se conectando. Se você estiver se conectando a um Banco de Dados SQL do Azure ou a um banco de dados SQL no Fabric, use a cadeia de conexão ODBC na guia cadeias de conexão. Talvez seja necessário ajustar o tipo de autenticação dependendo do seu cenário. Para obter mais informações sobre cadeias de conexão e sua sintaxe, consulte a referência de sintaxe da cadeia de conexão.
Criar um Jupyter Notebook
Selecione Arquivo e, em seguida, Novo Arquivo e Jupyter Notebook na lista. Um novo bloco de anotações é aberto.
Selecione Arquivo e, em seguida, Salve como... e dê um nome ao novo bloco de anotações.
Adicione as seguintes importações na primeira célula.
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 pltUse o botão + Markdown na parte superior do bloco de anotações para adicionar uma nova célula markdown.
Adicione o texto a seguir à nova célula markdown.
## Define queries for use laterSelecione a marca de seleção na barra de ferramentas da célula ou use os atalhos
Ctrl+Enterde teclado ouShift+Enterpara renderizar a célula markdown.Use o botão + Código na parte superior do bloco de anotações para adicionar uma nova célula de código.
Adicione o código a seguir à nova célula de código.
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; """
Exibir resultados em uma tabela
Use o botão + Markdown na parte superior do bloco de anotações para adicionar uma nova célula markdown.
Adicione o texto a seguir à nova célula markdown.
## Print orders by customer and display in a tableSelecione a marca de seleção na barra de ferramentas da célula ou use os atalhos
Ctrl+Enterde teclado ouShift+Enterpara renderizar a célula markdown.Use o botão + Código na parte superior do bloco de anotações para adicionar uma nova célula de código.
Adicione o código a seguir à nova célula de código.
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)Dica
Para usar a Autenticação do Microsoft Entra no macOS, você deve estar conectado por meio da extensão do Azure Repos no Visual Studio Code ou executando
az loginpor meio da CLI (Interface de Command-Line) do Azure.Use o botão Executar Tudo na parte superior do notebook para executá-lo.
Selecione o kernel jupyter-notebook-qs quando solicitado.
Exibir resultados em um gráfico
Examine a saída da última célula. Você deve ver uma tabela com três colunas e cinco linhas.
Use o botão + Markdown na parte superior do bloco de anotações para adicionar uma nova célula markdown.
Adicione o texto a seguir à nova célula markdown.
## Display spend by category in a horizontal bar chartSelecione a marca de seleção na barra de ferramentas da célula ou use os atalhos
Ctrl+Enterde teclado ouShift+Enterpara renderizar a célula markdown.Use o botão + Código na parte superior do bloco de anotações para adicionar uma nova célula de código.
Adicione o código a seguir à nova célula de código.
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'])Use o botão Executar Célula ou
Ctrl+Alt+Enterexecute a célula.Revise os resultados. Torne este bloco de anotações seu.
Próxima etapa
Visite o repositório GitHub do mssql-python driver para obter mais exemplos, contribuir com ideias ou relatar problemas.