Como: Classificar resultados de consulta 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 e classifica os resultados por vários campos usando a cláusula Order By
. A ordem de classificação para cada campo pode ser ordem crescente ou ordem decrescente. Para obter mais informações, consulte Order By Clause.
Os exemplos neste artigo usam o banco de dados de exemplo Northwind. Para obter a base de dados, consulte Descarregar 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
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 .
Clique com o botão direito do rato em Ligações de Dados no Explorador de Servidores/Explorador de Bases de Dados e, em seguida, clique em Adicionar Ligação.
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
No Visual Studio, no menu Arquivo, selecione Novo e depois clique em Projeto. Selecione Visual Basic Windows Forms Application como o tipo de projeto.
No menu Projeto, clique em Adicionar Novo Item. Selecione o modelo de item LINQ to SQL Classes.
Nomeie o arquivo
northwind.dbml
. Clique Adicionar. O Object Relational Designer (O/R Designer) é aberto para o arquivo northwind.dbml.
Para adicionar tabelas à consulta ao O/R Designer
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.
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
eOrder
objetos para o seu projeto. Observe que o designer detecta automaticamente relações entre as tabelas e cria propriedades filhas para objetos relacionados. Por exemplo, o IntelliSense mostrará que o objetoCustomer
tem uma propriedadeOrders
para todos os pedidos relacionados a esse cliente.Salve as alterações e feche o designer.
Salve seu projeto.
Para adicionar código para consultar o banco de dados e exibir os resultados
Na Caixa de Ferramentas do, arraste um controlo DataGridView para o Formulário Padrão do Windows para o seu projeto, o Form1.
Clique duas vezes em Form1 para adicionar código ao evento
Load
do formulário.Quando você adicionou tabelas ao O/R Designer, o designer adicionou um objeto DataContext ao 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 contexto de dados e classificar os resultados. A consulta classifica os resultados pelo número de pedidos do cliente, em ordem decrescente. Os clientes que têm o mesmo número de pedidos são ordenados pelo nome da empresa em ordem crescente (o padrão).Dim db As New northwindDataContext Dim q = From cust In db.Customers Where cust.Orders.Count > 0 Select cust.CustomerID, cust.CompanyName, OrderCount = cust.Orders.Count, cust.Country Order By OrderCount Descending, CompanyName DataGridView1.DataSource = q
Pressione F5 para executar seu projeto e visualizar os resultados.