Lição 3: Adicionando parâmetros para selecionar vários valores em uma lista
Nesta lição, você alterará os parâmetros BusinessPersonID e DayoftheWeek de parâmetros de valor único para parâmetros de vários valores. Os parâmetros de vários valores permitem selecionar mais de um valor para um parâmetro de relatório. Para modificar o parâmetro de relatório BusinessPersonID, você alterará a consulta para o conjunto de dados AdventureWorks2008 para testar o @BusinessPersonID no conjunto de valores selecionado em vez de equalizar para um único valor e verificará a propriedade de vários valores do parâmetro de relatório. Para modificar o parâmetro de relatório DayoftheWeek, você verificará a propriedade de vários valores, definirá os valores disponíveis de um novo conjunto de dados e fornecerá uma expressão para os valores padrão. Você criará um novo conjunto de dados para fornecer os valores disponíveis para o parâmetro DayoftheWeek. Finalmente, você adicionará uma caixa de texto ao relatório para exibir valores de parâmetros para as seleções de DayoftheWeek feitas.
Para substituir o conjunto de dados existente
No painel Dados do Relatório, clique com o botão direito do mouse no conjunto de dados AdventureWorksDataset e clique em Propriedades do Conjunto de Dados.
Em Fonte de Dados, verifique se o AdventureWorks_Ref está selecionado.
Em Tipo de consulta, verifique se Texto está selecionado.
Clique no botão Designer de Consulta para abrir o designer de consulta.
Substitua o texto pela seguinte consulta na caixa de texto:
SELECT soh.OrderDate AS [Date], DATENAME(weekday, soh.OrderDate) as Weekday, soh.SalesOrderNumber AS [Order], pps.Name AS Subcat, pp.Name as Product, SUM(sd.OrderQty) AS Qty, SUM(sd.LineTotal) AS LineTotal FROM Sales.SalesPerson sp INNER JOIN Sales.SalesOrderHeader AS soh ON sp.BusinessEntityID = soh.SalesPersonID INNER JOIN Sales.SalesOrderDetail AS sd ON sd.SalesOrderID = soh.SalesOrderID INNER JOIN Production.Product AS pp ON sd.ProductID = pp.ProductID INNER JOIN Production.ProductSubcategory AS pps ON pp.ProductSubcategoryID = pps.ProductSubcategoryID INNER JOIN Production.ProductCategory AS ppc ON ppc.ProductCategoryID = pps.ProductCategoryID GROUP BY ppc.Name, soh.OrderDate, soh.SalesOrderNumber, pps.Name, pp.Name, soh.SalesPersonID HAVING ppc.Name = 'Clothing' AND (soh.OrderDate BETWEEN (@StartDate) AND (@EndDate)) AND soh.SalesPersonID IN (@BusinessPersonID)
Esta é a mesma consulta anterior, mas uma condição foi alterada de igualdade para inclusão.
AND soh.SalesPersonID IN (@BusinessPersonID)
Clique no botão Executar (!). Quando os parâmetros de consulta forem solicitados, use a seguinte tabela para digitar valores. O designer de consulta não dá suporte a teste de parâmetros de vários valores.
@StartDate
20010101
@EndDate
20030101
@BusinessPersonID
290
Clique em OK.
O conjunto de resultados é exibido para o vendedor Ranjit Varkey Chudukatil com BusinessPersonID = 290.
Para editar o parâmetro de relatório BusinessPersonID para aceitar vários valores
No painel Dados do Relatório, expanda Parâmetros e clique duas vezes no parâmetro BusinessPersonID.
Selecione a opção Permitir vários valores.
Clique em OK.
Clique em Visualizar. O relatório é executado automaticamente. Uma lista suspensa para BusinessPersonID mostra todos os nomes dos vendedores.
Observação |
---|
Um valor de (Selecionar Tudo) é fornecido como o primeiro valor em uma lista suspensa de valores disponíveis para um parâmetro de vários valores. Use essa caixa de seleção para selecionar tudo ou limpar todos os valores. Por padrão, todos os valores são selecionados. |
Para adicionar um novo conjunto de dados para popular os valores válidos para um parâmetro de relatório
Alterne para o modo Design.
No painel Dados do Relatório, clique com o botão direito do mouse em AdventureWorks_Ref e clique em Adicionar Conjunto de Dados. A caixa de diálogo Propriedades do Conjunto de Dados é aberta.
No campo Nome, digite WeekDaysfromQuery.
Em Tipo de consulta, verifique se Text está selecionado.
Em Consulta, digite ou cole a seguinte cadeia de caracteres da consulta:
SET DATEFIRST 1; SELECT DISTINCT DATEPART(weekday, S.OrderDate) as WeekDayNumber, DATENAME(weekday, S.OrderDate) as Weekday FROM Sales.SalesOrderHeader S Order by WeekDayNumber
Clique no botão Executar (!) na barra de ferramentas do designer de consultas. O conjunto de resultados mostra números ordinais e os dias da semana.
Clique em OK duas vezes para sair da caixa de diálogo Propriedades do sistema.
O conjunto de dados WeekDaysfromQuery é exibido no painel Dados do Relatório.
Para editar um parâmetro para aceitar valores vários, valores padrão e valores válidos
No painel Dados do Relatório, expanda Parâmetros e clique duas vezes em DayoftheWeek. A caixa de diálogo Propriedades do Parâmetro do Relatório é aberta.
Selecione Permitir vários valores.
Clique em Valores Disponíveis.
Selecione Obter valores de uma consulta.
Em Conjunto de Dados, na lista suspensa, selecione WeekDaysfromQuery.
Em Campo de valor, na lista suspensa, selecione Dia da Semana.
Em Campo de rótulo, na lista suspensa, selecione Dia da Semana.
Clique em Valores Padrão.
Selecione Especificar valores.
(Opcional) Selecione o valor existente Sexta-feira e clique em Excluir.
Clique em Adicionar.
Em Valor, digite Sábado.
Clique em Adicionar.
Em Valor, digite Domingo.
Clique em OK.
Para que seja possível visualizar o relatório, é necessário alterar a expressão de filtro definida para a região de dados Tabela para usar o operador IN porque o parâmetro DayoftheWeek aceita vários valores.
Para alterar um filtro para usar um parâmetro de vários valores
Na exibição Design, clique com o botão direito do mouse na tabela e clique em Propriedades do Tablix. A caixa de diálogo Propriedades do Tablix é aberta.
Clique em Filtros. Já existe um filtro que foi adicionado para DaysoftheWeek na Lição 1.
Em Expressão, na lista suspensa, verifique se o valor é [Weekday].
Verifique se Text está selecionado.
Altere o Operador do sinal de igual (=) para o operador Em.
Na caixa de texto Valor, na lista suspensa, verifique se o valor é [@DayoftheWeek].
Clique em OK.
O filtro da tabela agora está definido para comparar o valor do campo Dia da Semana com o valor do parâmetro DayoftheWeek usando o operador In. Quando você escolhe vários valores para o parâmetro do relatório, o filtro testará cada linha da tabela para ver se o campo Dia da Semana existe na coleção DayoftheWeek.
Clique em Visualizar. O relatório mostra o parâmetro do relatório DaysoftheWeek com os valores padrão Sábado e Domingo. Use a lista suspensa para selecionar vários valores para o parâmetro DayoftheWeek.
Próximas etapas
Você alterou propriedades de parâmetros de relatório de valor único para vários valores, com êxito. Você fez as alterações necessárias em uma consulta, em um filtro e em uma expressão para acomodar o uso de uma coleção de parâmetros de vários valores. Você aprendeu a usar parâmetros de vários valores em uma expressão. Na próxima lição, você aprenderá como criar parâmetros cujos valores são populados condicionalmente com base em um valor selecionado de um parâmetro anterior. Consulte Lição 4: Adicionando parâmetros em cascata.