Partilhar via


Como contar, somar ou média de dados usando LINQ (Visual Basic)

O Language-Integrated Query (LINQ) facilita o acesso às informações do banco de dados e a execução de consultas.

O exemplo a seguir mostra como criar um novo aplicativo que executa consultas em um banco de dados do SQL Server. A amostra conta, soma e calcula a média dos resultados usando as cláusulas Aggregate e Group By. Para obter mais informações, consulte Cláusula de Agregação e Cláusula GROUP BY.

Os exemplos neste artigo usam o banco de dados de exemplo Northwind. Para obter a base de dados, consulte Descarregamento de bases de dados de exemplo..

Observação

Seu computador pode mostrar nomes ou locais diferentes para alguns dos elementos da interface do usuário do Visual Studio nas instruções a seguir. A edição do Visual Studio que você tem e as configurações que você usa determinam esses elementos. Para obter mais informações, consulte Personalizando o IDE.

Para criar uma conexão com um banco de dados

  1. No Visual Studio, abra Gerenciador de Servidores/Explorador de Banco de Dados clicando em Gerenciador de Servidores/Explorador de Banco de Dados no menu Exibir .

  2. Clique com o botão direito do rato em Ligações de Dados no Explorador do Servidor/Explorador de Bases de Dados e, em seguida, clique em Adicionar Conexão.

  3. Especifique uma conexão válida com o banco de dados de exemplo Northwind.

Para adicionar um projeto que contém um arquivo LINQ to SQL

  1. No Visual Studio, no menu Arquivo, aponte para Novo e clique em Projeto. Selecione Visual Basic Windows Forms Application como o tipo de projeto.

  2. No menu Projeto, clique em Adicionar Novo Item. Selecione o modelo de item LINQ to SQL Classes.

  3. Nomeie o arquivo northwind.dbml. Clique Adicionar. O Object Relational Designer (O/R Designer) é aberto para o arquivo northwind.dbml.

Para adicionar tabelas na consulta do O/R Designer

  1. No Server Explorer/Database Explorer, expanda a conexão com o banco de dados Northwind. Expanda a pasta Tabelas.

    Se você tiver fechado o O/R Designer, poderá reabri-lo clicando duas vezes no arquivo northwind.dbml adicionado anteriormente.

  2. Clique na tabela Clientes e arraste-a para o painel esquerdo do designer. Clique na tabela Pedidos e arraste-a para o painel esquerdo do designer.

    O designer cria novos Customer e Order objetos para o seu projeto. Observe que o designer deteta automaticamente relações entre as tabelas e cria propriedades filhas para objetos relacionados. Por exemplo, o IntelliSense mostrará que o objeto Customer tem uma propriedade Orders para todos os pedidos relacionados a esse cliente.

  3. Salve as alterações e feche o designer.

  4. Salve seu projeto.

Para adicionar código para consultar o banco de dados e exibir os resultados

  1. Na Caixa de Ferramentas , arraste um controlo DataGridView para o Formulário Windows padrão do seu projeto, Form1.

  2. Clique duas vezes em Form1 para adicionar código ao evento Load do formulário.

  3. Quando você adicionou tabelas ao O/R Designer, o designer adicionou um objeto DataContext para seu projeto. Este objeto contém o código que você deve ter para acessar essas tabelas e para acessar objetos e coleções individuais para cada tabela. O objeto DataContext para seu projeto é nomeado com base no nome do seu arquivo .dbml. Para este projeto, o objeto DataContext é chamado northwindDataContext.

    Você pode criar uma instância do DataContext em seu código e consultar as tabelas especificadas pelo O/R Designer.

    Adicione o seguinte código ao evento Load para consultar as tabelas que são expostas como propriedades do seu DataContext e contar, somar e calcular a média dos resultados. O exemplo usa a cláusula Aggregate para consultar um único resultado e a cláusula Group By para mostrar uma média para resultados agrupados.

    Dim db As New northwindDataContext
    Dim msg = ""
    
    Dim londonCustomerCount = Aggregate cust In db.Customers
                              Where cust.City = "London"
                              Into Count()
    msg &= "Count of London Customers: " & londonCustomerCount & vbCrLf
    
    Dim averageOrderCount = Aggregate cust In db.Customers
                            Where cust.City = "London"
                            Into Average(cust.Orders.Count)
    msg &= "Average number of Orders per customer: " &
           averageOrderCount & vbCrLf
    
    Dim venezuelaTotalOrders = Aggregate cust In db.Customers
                               Where cust.Country = "Venezuela"
                               Into Sum(cust.Orders.Count)
    msg &= "Total number of orders from Customers in Venezuela: " &
           venezuelaTotalOrders & vbCrLf
    
    MsgBox(msg)
    
    Dim averageCustomersByCity = From cust In db.Customers
                                 Group By cust.City
                                 Into Average(cust.Orders.Count)
                                 Order By Average
    
    DataGridView1.DataSource = averageCustomersByCity
    
    'Another way to grab the count and sum
    
    londonCustomerCount = (From cust in db.Customers
                           Where cust.City = "London").Count()
    
    venezuelaTotalOrders = (From cust in db.Customers
                            Where cust.Country = "Venezuela"
                            Select cust.Orders).Sum()
    
  4. Pressione F5 para executar seu projeto e visualizar os resultados.

Ver também