Como chamar um procedimento armazenado usando LINQ (Visual Basic)
Language-Integrated Consulta (LINQ) facilita o acesso às informações do banco de dados, incluindo objetos de banco de dados, como procedimentos armazenados.
O exemplo a seguir mostra como criar um aplicativo que chama um procedimento armazenado em um banco de dados do SQL Server. O exemplo mostra como chamar dois procedimentos armazenados diferentes no banco de dados. Cada procedimento retorna os resultados de uma consulta. Um procedimento usa parâmetros de entrada e o outro procedimento não usa parâmetros.
Os exemplos neste artigo usam o banco de dados de exemplo Northwind. Para obter o banco de dados, consulte Baixando bancos de dados de exemplo.
Nota
Seu computador pode mostrar nomes ou locais diferentes para alguns dos elementos de 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 Explorador de Servidores/Explorador de Banco de Dados clicando em Explorador de Servidores/Explorador de Banco de Dados no menu Exibir.
Clique com o botão direito em Conexões de Dados no Explorador de Servidores/Explorador de Banco de Dados e depois clique em Adicionar Conexão.
Especifique uma conexão válida com o banco de dados de exemplo Northwind.
Para adicionar um projeto que contém um LINQ ao arquivo SQL
No Visual Studio, no menu Arquivo, aponte para Novo e clique em Projeto. Selecione Aplicativo do Windows Forms no Visual Basic como o tipo de projeto.
No menu Project, clique em Adicionar Novo Item. Selecione o modelo de item Classes LINQ to SQL.
Nomeie o arquivo
northwind.dbml
. Clique em Adicionar. O Designer Relacional de Objeto (Designer O/R) é aberto para o arquivo northwind.dbml.
Para adicionar procedimentos armazenados ao Designer O/R
No Gerenciador de Servidores/Gerenciador de Banco de Dados, expanda a conexão com o banco de dados Northwind. Expanda a pasta Procedimentos Armazenados .
Se você fechou o Designer O/R, poderá reabri-lo clicando duas vezes no arquivo northwind.dbml que você adicionou anteriormente.
Clique no procedimento armazenado Vendas por Ano e arraste-o para o painel direito do designer. Clique no procedimento armazenado Dez Produtos Mais Caros arraste-o para o painel direito do designer.
Salve suas alterações e feche o designer.
Salve seu projeto.
Para adicionar código para exibir os resultados dos procedimentos armazenados
Na Caixa de Ferramentas, arraste um controle DataGridView para o Windows Form padrão para seu projeto, Form1.
Clique duas vezes no Form1 para adicionar código ao evento
Load
.Quando você adicionou procedimentos armazenados ao Designer O/R, o designer adicionou um objeto DataContext para seu projeto. Esse objeto contém o código que você deve ter para acessar esses procedimentos. O objeto DataContext do projeto é nomeado com base no nome do arquivo .dbml. Para este projeto, o objeto DataContext é nomeado
northwindDataContext
.Você pode criar uma instância do DataContext código e chamar os métodos de procedimento armazenado especificados pelo Designer O/R. Para associar-se ao objeto DataGridView, talvez seja necessário forçar a execução da consulta imediatamente chamando o método ToList nos resultados do procedimento armazenado.
Adicione o seguinte código ao evento
Load
para chamar um dos procedimentos armazenados expostos como métodos para o seu contexto de dados.Dim db As New northwindDataContext ' Display the results of the Sales_by_Year stored procedure. DataGridView1.DataSource = db.Sales_by_Year(#1/1/1996#, #1/1/2007#).ToList()
' Display the results of the Ten_Most_Expensive_Products ' stored procedure. DataGridView1.DataSource = db.Ten_Most_Expensive_Products.ToList()
Pressione F5 para executar seu projeto e exibir os resultados.