Conexões de dados, fontes de dados e cadeias de conexão no Reporting Services
Para incluir dados em um relatório do Reporting Services, você deve primeiro criar fontes de dados e conjuntos de dados. Este tópico explica o tipo de fontes de dados, como criar fontes de dados e informações importantes relacionadas às credenciais de fontes de dados. Uma fonte de dados inclui o tipo da fonte de dados, informações da conexão e o tipo de credenciais a serem usadas. Há dois tipos de fontes de dados: inserida ou compartilhada. Um fonte de dados inserida é definida no relatório e usada apenas por esse relatório. Uma fonte de dados compartilhada é definida independentemente de um relatório e pode ser usada por vários relatórios. Para obter mais informações, consulte Conexões de dados inseridas e compartilhadas ou fontes de dados (Construtor de Relatórios e SSRS) e Conjuntos de dados inseridos e compartilhados (Construtor de Relatórios e SSRS).
Aplica-se a: Modo Nativo do Reporting Services | Modo do SharePoint do Reporting Services |
Observação
Você pode criar e modificar definições de relatório (.rdl) no Construtor de Relatórios e no Designer de Relatórios no SQL Server Data Tools. Cada ambiente de criação fornece modos diferentes para criar, abrir e salvar relatórios e itens relacionados. Para obter mais informações, consulte Criando relatórios no Designer de Relatórios e no Construtor de Relatórios (SSRS) na Web em microsoft.com.
Fontes de dados inseridas e compartilhadas
A diferença entre as fontes de dados inseridas e compartilhadas está em como elas são criadas, armazenadas e gerenciadas.
No Designer de Relatórios, crie fontes de dados inseridas e compartilhadas como parte de um projeto do SSDT (SQL Server Data Tools). Você pode controlar se elas devem ser usadas localmente para visualização ou implantadas como parte do projeto para um servidor de relatório ou site do SharePoint. Você pode usar extensões de dados personalizadas que foram instaladas em seu computador e no servidor de relatório ou site do SharePoint onde você implanta seus relatórios.
Os administradores do sistema podem instalar e configurar extensões de processamento de dados adicionais e provedores de dados do .NET Framework. Para obter mais informações, confira Extensões de processamento de dados e provedores de dados do .NET Framework (SSRS).
Os desenvolvedores podem usar a API Microsoft.ReportingServices.DataProcessing para criar extensões de processamento de dados para dar suporte a tipos de fonte de dados adicionais.
No Construtor de Relatórios, navegue para um servidor de relatório ou site do SharePoint e selecione fontes de dados compartilhadas ou crie fontes de dados inseridas no relatório. Não é possível criar uma fonte de dados compartilhada no Construtor de Relatórios. Você não pode usar extensões de dados personalizadas no Construtor de Relatórios
Extensões de dados internas
As extensões de dados padrão no Reporting Services incluem os seguintes tipos de conexões de dados:
Microsoft SQL Server
Microsoft SQL Server Analysis Services
Lista do Microsoft SharePoint
Banco de Dados SQL do Azure
Microsoft SQL Server Parallel Data Warehouse
OLE DB
Oracle
SAP NetWeaver BI
Hyperion Essbase
Teradata
XML
ODBC
Modelo semântico do Microsoft BI para o Power View: em um site do SharePoint que foi configurado para uma galeria do PowerPivot e o Power View, esse tipo de fonte de dados está disponível. Esse tipo de fonte de dados é usado apenas para apresentações do Power View. Para mais informações, consulte Criando modelos semânticos de tabelas perfeitos de BI para Power View.
Para obter uma lista completa de fontes de dados e versões aos quais o Reporting Services dá suporte, confira Fontes de dados com suporte no Reporting Services (SSRS).
Criar uma fonte de dados
Para criar uma fonte de dados, você deve ter as seguintes informações:
Tipo de fonte de dados O tipo de conexão, por exemplo, Microsoft SQL Server. Escolha esse valor na lista suspensa de tipos de conexão.
Informações de conexão As informações de conexão incluem o nome e o local da fonte de dados e as propriedades de conexão específicas para cada provedor de dados. A cadeia de conexão é a representação de texto das informações de conexão. Por exemplo, se a fonte de dados for um banco de dados do SQL Server, você poderá especificar o nome do banco de dados. Para fontes de dados inseridas, também é possível gravar cadeias de conexão baseadas em expressão que são avaliadas em tempo de execução. Para obter mais informações, consulte Cadeias de conexão baseadas em expressão mais adiante neste tópico.
Credenciais Você fornece as credenciais necessárias para acessar os dados. O proprietário da fonte de dados deve ter concedido a você as permissões adequadas para acessar a fonte de dados e os dados específicos na fonte de dados. Por exemplo, para se conectar ao banco de dados de exemplo AdventureWorks2012 instalado em um servidor de rede, você deve ter permissão para se conectar ao servidor e também permissão somente leitura para acessar o banco de dados.
Observação
Por design, as credenciais são gerenciadas de maneira independente das fontes de dados. As credenciais usadas para visualizar seu relatório em um sistema local podem ser diferentes das credenciais necessárias para exibir o relatório publicado. Depois de salvar uma fonte de dados no servidor de relatório ou site do SharePoint, pode ser necessário alterar as credenciais para trabalhar daquele local. Para obter mais informações, consulte Credenciais para fontes de dados.
Observação
Ao criar uma fonte de dados inserida para um relatório no SSDT (SQL Server Data Tools), você deve criar a fonte de dados no Designer de Relatórios no Gerenciador de Soluções ou no painel Dados do Relatório, mas não no Gerenciador de Servidores. O Designer de Relatórios do SQL Server não dá suporte a fontes de dados do Visual Studio criadas no Gerenciador de Servidores.
O painel de dados do relatório exibe fontes de dados inseridas e referências a fontes de dados compartilhadas que foram adicionadas ao relatório. No Construtor de Relatórios, uma referência a uma fonte de dados compartilhada aponta para uma fonte de dados compartilhada em um servidor de relatório ou no site do SharePoint. No Designer de Relatórios, uma referência a uma fonte de dados compartilhada aponta para uma fonte de dados compartilhada no Gerenciador de Soluções na pasta Fonte de Dados Compartilhada.
Credenciais para fontes de dados
Por design, as credenciais podem ser salvas e gerenciadas independentemente das informações de conexão. As credenciais são usadas para criar uma fonte de dados, para executar uma consulta de conjunto de dados e para visualizar um relatório.
Observação
É recomendável não incluir informações de logon, como nomes de logon e senhas, às propriedades de conexão da fonte de dados. Use fontes de dados compartilhadas com credenciais armazenadas sempre que possível. Em um ambiente de criação, use a página Credenciais da caixa de diálogo Fonte de Dados para inserir credenciais ao criar uma conexão de dados ou ao executar uma consulta de conjunto de dados.
As credenciais inseridas para acesso a dados em seu computador são armazenados com segurança no arquivo de configuração do projeto local e são específicas a seu computador. Se você copiar os arquivos do projeto em outro computador, deverá redefinir as credenciais da fonte de dados.
Ao implantar um relatório no servidor de relatório ou site do SharePoint, suas fontes de dados inseridas e compartilhadas são gerenciadas de maneira independente. As credenciais da fonte de dados necessárias para acessar os dados de seu computador podem ser diferentes das credenciais necessárias para o servidor de relatório para acessar os dados.
Uma boa prática é verificar se as conexões da fonte de dados continuam a se conectar com êxito após a publicação de um relatório. Se for necessário alterar as credenciais, você poderá modificá-las diretamente no servidor de relatório.
Para alterar as fontes de dados que um relatório usa, você pode modificar as propriedades do relatório no modo Nativo Gerenciador de Relatórios ou em bibliotecas de documentos no modo SharePoint. Para saber mais, consulte o seguinte:
Armazenar credenciais em uma fonte de dados do Reporting Services Armazenar credenciais em uma fonte de dados do Reporting Services
Especificar informações de credenciais e de conexão para fontes de dados de relatório
Especificar conexões para extensões de processamento de dados personalizadas
Adicionar e verificar uma conexão de dados ou fonte de dados (Construtor de Relatórios e SSRS)
Exemplos comuns de cadeia de conexão
Cadeias de conexão são a representação de texto de propriedades de conexão para um provedor de dados. A tabela a seguir lista exemplos de cadeias de conexão para vários tipos de conexão de dados.
Fonte de dados | Exemplo | Descrição |
---|---|---|
Banco de dados do SQL Server no servidor local | data source="(local)";initial catalog=AdventureWorks |
Defina o tipo da fonte de dados como Microsoft SQL Server . Para obter mais informações, confira Tipo de conexão do SQL Server (SSRS). |
Banco de dados do SQL Server no servidor local | data source="(local)";initial catalog=AdventureWorks |
Defina o tipo da fonte de dados como Microsoft SQL Server . |
Instância do SQL Server Banco de Dados |
Data Source=localhost\MSSQL10_50.InstanceName; Initial Catalog=AdventureWorks |
Defina o tipo da fonte de dados como Microsoft SQL Server . |
Banco de dados do SQL Server Express | Data Source=localhost\MSSQL10_50.SQLEXPRESS; Initial Catalog=AdventureWorks |
Defina o tipo da fonte de dados como Microsoft SQL Server . |
Banco de dados SQL na nuvem | Data Source=<host>;Initial Catalog=AdventureWorks; Encrypt=True |
Defina o tipo da fonte de dados como Azure SQL Database . Para obter mais informações, consulte Tipo de conexão do SQL Azure (SSRS). |
SQL Server Parallel Data Warehouse | HOST=<IP address>;database= AdventureWorks; port=<port> |
Defina o tipo da fonte de dados como Microsoft SQL Server Parallel Data Warehouse . Para obter mais informações, confira Tipo de conexão do SQL Server Parallel Data Warehouse (SSRS). |
Banco de dados do Analysis Services no servidor local | data source=localhost;initial catalog=Adventure Works DW |
Defina o tipo da fonte de dados como Microsoft SQL Server Analysis Services . Para obter mais informações, confira Tipo de conexão do Analysis Services para MDX (SSRS) ou Tipo de conexão do Analysis Services para DMX (SSRS). |
Banco de dados modelo de tabela do Analysis Services com perspectiva de vendas | Data source=<servername>;initial catalog= Adventure Works DW;cube='Sales' |
Defina o tipo da fonte de dados como Microsoft SQL Server Analysis Services . Especifique o nome da perspectiva na configuração de cube=. Para obter mais informações, confira Perspectivas (SSAS de Tabela). |
Fonte de dados de modelo de relatório em um servidor de relatório configurado em modo nativo | Server=http://myreportservername/reportserver; datasource=/models/Adventure Works |
Especifique o servidor de relatório ou a URL da biblioteca de documentos e o caminho para o modelo publicado na pasta do servidor de relatório ou no namespace da pasta da biblioteca de documentos. |
Fonte de dados de modelo de relatório em um servidor de relatório configurado em modo integrado do SharePoint | Server=https://server; datasource=https://server/site/documents/models/Adventure Works.smdl |
Especifique o servidor de relatório ou a URL da biblioteca de documentos e o caminho para o modelo publicado na pasta do servidor de relatório ou no namespace da pasta da biblioteca de documentos. |
Servidor do SQL Server 2000 Analysis Services | provider=MSOLAP.2;data source=<remote server name>;initial catalog=FoodMart 2000 |
Defina o tipo da fonte de dados como OLE DB Provider for OLAP Services 8.0 .Você pode obter uma conexão mais rápida com as fontes de dados do SQL Server 2000 Analysis Services se definir a ConnectTo propriedade como 8.0 . Para definir essa propriedade, use a caixa de diálogo Propriedades da Conexão , guia Propriedades Avançadas . |
Servidor do Oracle | data source=myserver |
Defina o tipo da fonte de dados como Oracle . As ferramentas do cliente Oracle devem estar instaladas no computador de Designer de Relatórios e no servidor de relatório. Para obter mais informações, confira Tipo de conexão Oracle (SSRS). |
Fonte de dados do SAP NetWeaver BI | DataSource=http://mySAPNetWeaverBIServer:8000/sap/bw/xml/soap/xmla |
Defina o tipo da fonte de dados como SAP NetWeaver BI . Para obter mais informações, confira Tipo de conexão SAP NetWeaver BI (SSRS). |
Fonte de dados do Hyperion Essbase | Data Source=https://localhost:13080/aps/XMLA; Initial Catalog=Sample |
Defina o tipo da fonte de dados como Hyperion Essbase . Para obter mais informações, confira Tipo de conexão Hyperion Essbase (SSRS). |
Fonte de dados do Teradata | data source= <NNN.><NNN.><NNN.><NNN>; |
Defina o tipo da fonte de dados como Teradata . A cadeia de conexão é um endereço IP no formulário de quatro campos, em que cada campo pode ter de um a três dígitos. Para obter mais informações, confira Tipo de conexão Teradata (SSRS). |
Fonte de dados XML, serviço Web | data source=http://adventure-works.com/results.aspx |
Defina o tipo da fonte de dados como XML . A cadeia de conexão é uma URL para um serviço Web com suporte para WSDL. Para obter mais informações, confira Tipo de conexão XML (SSRS). |
Fonte de dados XML, documento XML | https://localhost/XML/Customers.xml |
Defina o tipo da fonte de dados como XML . A cadeia de conexão é uma URL para o documento XML. |
Fonte de dados XML, documento XML inserido | Empty (vazio) | Defina o tipo da fonte de dados como XML . Os dados XML são inseridos na definição do relatório. |
Se não for possível conectar a um servidor de relatório que use localhost
, verifique se o protocolo de rede TCP/IP está habilitado. Para obter mais informações, consulte Configure Client Protocols.
Caracteres especiais em uma senha
Se você configurar a fonte de dados ODBC ou SQL para solicitar uma senha ou para incluir uma senha na cadeia de conexão e o usuário inserir a senha com caracteres especiais, como sinais de pontuação, alguns drivers de fonte de dados subjacentes não conseguirão validar os caracteres especiais. Quando você processar o relatório, a mensagem "Senha inválida" poderá indicar esse problema. Se não for possível alterar a senha, você poderá trabalhar com o administrador do banco de dados para armazenar as credenciais apropriadas no servidor como parte de um DSN (nome da fonte de dados) do sistema ODBC. Para obter mais informações, consulte "OdbcConnection.ConnectionString" na documentação do .NET Framework SDK.
Cadeias de conexão baseadas em expressão
Cadeias de conexão baseadas em expressão são avaliadas em tempo de execução. Por exemplo, você pode especificar a fonte de dados como um parâmetro, incluir a referência ao parâmetro na cadeia de conexão e permitir que o usuário escolha a fonte de dados para o relatório. Por exemplo, suponha que uma empresa multinacional tem servidores de dados em vários países/regiões. Com uma cadeia de conexão baseada em expressão, um usuário que está executando um relatório de vendas pode selecionar uma fonte de dados para um país/região específico antes de executar o relatório.
O exemplo a seguir ilustra o uso de uma expressão de fonte de dados em uma cadeia de conexão do SQL Server. O exemplo assume que você criou um parâmetro de relatório denominado ServerName
:
="data source=" & Parameters!ServerName.Value & ";initial catalog=AdventureWorks"
Expressões de fonte de dados são processadas em tempo de execução ou quando um relatório é visualizado. A expressão deve ser escrita no Visual Basic. Use as seguintes diretrizes ao definir uma expressão de fonte de dados:
Crie o relatório usando uma cadeia de conexão estática. Uma cadeia de conexão estática faz referência a uma cadeia de conexão que não é definida através de uma expressão (por exemplo, quando você segue as etapas para criar uma fonte de dados específica ao relatório ou compartilhada, você está definindo um cadeia de conexão estática. O uso de uma cadeia de conexão estática permite conectar à fonte de dados no Designer de Relatórios de forma que você possa obter os resultados da consulta necessários para criar o relatório.
Ao definir a conexão da fonte de dados, não use uma fonte de dados compartilhada. Não é possível usar uma expressão de fonte de dados em uma fonte de dados compartilhada. Você deve definir uma fonte de dados inserida para o relatório.
Especifique credenciais separadamente da cadeia de conexão. É possível usar credenciais armazenadas, credenciais solicitadas ou segurança integrada.
Adicione um parâmetro de relatório para especificar uma fonte de dados. Para os valores dos parâmetros, você pode fornecer uma lista estática de valores disponíveis (neste caso, os valores disponíveis devem ser fontes de dados usadas com o relatório) ou definir uma consulta que recupere uma lista de fontes de dados em tempo de execução.
Verifique se a lista de fontes de dados compartilha o mesmo esquema de banco de dados. Todo design de relatório começa com informações de esquema. Se houver uma incompatibilidade entre o esquema usado para definir o relatório e o esquema real usado pelo relatório em tempo de execução, o relatório poderá não ser executado.
Antes de publicar o relatório, substitua a cadeia de conexão estática por uma expressão. Espere até a conclusão do design do relatório para substituir a cadeia de conexão estática por uma expressão. Ao usar uma expressão, você não pode executar a consulta no Designer de Relatórios. Além disso, a lista de campos no painel de dados do relatório e a lista de Parâmetros não serão atualizadas automaticamente.
Confira também
Conexões de dados ou fontes de dados inseridas e compartilhadas (Construtor de Relatórios e SSRS)Caixa de diálogo Gerenciar propriedadesda fonte de dados de fontes de dados de relatório, Caixa de diálogo Propriedades da fonte de dados compartilhada de credenciais, Criar, modificar e excluir fontes de dados compartilhadas (SSRS) de credenciaisDefinir propriedades de implantação (Reporting Services)Especificar informações de credenciais e conexão para fontes de dados de relatórioAdicionar e verificar uma conexão de dados ou fonte de dados (Construtor de Relatórios e SSRS)