Revista Active Delphi
terça-feira, 9 de fevereiro de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos


MVP Profile
Acessando banco de dados em .Net - Parte 2
Por: Marden Menezes
[Entre em contato com o autor ]
Líder do maior grupo de usuários do Brasil, o Sharp Shooters (www.sharpshooters.org.br). Marden é Microsoft Certified Professional e Microsoft Student Ambassador, ministrando palestras e cursos em todo o Brasil e difundindo a plataforma .NET nas universidades.
Como representante do comitê de relacionamento com grupos de usuários da INETA (www.ineta.org), Marden vem trabalhando para a difusão dos grupos de usuários .NET no país.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
Acessando banco de dados em .Net - Parte 2
Publicado em: 20/01/2004

Olá pessoal, tudo bem?
Neste artigo estarei mostrando a vocês como desenvolver usando ADO .NET para acesso a dados no modelo conectado.

O MODELO CONECTADO

Essa é a maneira mais comum de acessar banco de dados e segue o que normalmente fazemos no nosso dia a dia. A idéia é, todas as vezes que precisamos de alguma informação, nos conectamos a base de dados e carregamos essa informação. Esse modelo nos permite termos sempre a informação o mais atualizada possível e é ideal para sistemas em que os dados mudam o tempo todo e que precisam das informações atualizadas. Um bom exemplo disso é um controle de estoque que precisa saber "on-the-fly" informações que mudam o tempo todo. A quantidade de produtos pode ter mudado inúmeras vezes e você precisa saber a informação mais atualizada. Essa é a idéia! Um problema desse modelo é o fato de que todas as vezes em que é preciso recuperar uma informação é preciso se conectar a base de dados. Isso causa um tráfego maior na rede deixando-a sobrecarregada.

CODIFICANDO PARA MODELO CONECTADO

Mostrei no artigo passado como criar um objeto que representa a conexão ao banco. Além disso precisaremos também ter um objeto chamado XXXCommand. O XXXCommand servirá para executar algum comando SQL no banco de dados. Como vocês perceberam, coloquei XXX antes do nome Command. Esse padrão é usado para definir que o objeto depende do banco de dados e do Provider (se não se lembra o que é Provider, por favor, leia a primeira parte de acesso a dados com .NET). Se estivéssemos trabalhando com uma base de dados SQL Server, por exemplo, usaríamos o SqlCommand.

Se vocês ainda se lembram (faz um tempão...), usamos um banco de dados Access no artigo anterior, então usaremos o objeto OleDbCommand, pois estaremos usando o provedor OLEDB para acessar os nossos registros.

Vamos então criar um objeto OleDbCommand. Podemos fazer isso de duas formas:

//usando a palavra reservada "new"
OleDbCommand comando = new OleDbCommand(...);

Temos 4 diferentes construtores para o OleDbCommand, e você pode escolher dependendo da sua necessidade:

  • OleDbCommand() - o construtor vazio

  • OleDbCommand(string cmdSQL, System.Data.OleDbConnection connection, System.Data.OleDbTransaction transacao) - construtor que recebe uma string SQL que guardada na propriedade CommandText do objeto OleDbCommand criado para depois ser executada no banco de dados; um objeto OleDbConnection que será guardado na propriedade Connection do comando; um objeto OleDbTransaction que representa a transação ao qual esse comando está ligado e será guardado na propriedade Trasaction do comando.

  • OleDbCommand(string cmdSQL) - recebe apenas a string SQL a ser executada

  • OleDbCommand(string cmdSQL, System.Data.OleDbConnection connection) - recebe apenas a string SQL e a conexão ao qual o comando está ligado
É importante lembrar que você pode setar essas propriedades (conexao, transação, etc...) após a criação do objeto, sem necessidade de seta-los no construtor.

A segunda maneira é usando o método CreateCommand de uma conexão:

//criando a conexão e passando uma string de conexão como parâmetro
OleDbConnection conexao = new OleDbConnection(strConexao);

// criando o comando através da conexão:
OleDbCommand comando = conexao.CreateCommand();

//setando a string SQL do comando
comando.CommandText = "INSERT INTO <table> AlgumaCoisa";

A PROPRIEDADE CommandText

É importante lembrar que nem sempre (na verdade, quase nunca) nós setamos a string SQL diretamente no código de desenvolvimento. Normalmente usamos Stored Procedures. Para setar o CommandText para ser usado com o seu stored procedure, faça como segue:

//setando o CommandText com o nome do Stored Procedure
comando.CommandText = "NomeDoSP";
			
//setando o tipo do comando para StoredProcedure
comando.CommandType = System.Data.CommandType.StoredProcedure;

Quando setamos o CommandText para uma string SQL não precisamos setar o CommandType para System.Data.CommandType.Text porque esse já é o valor padrão da propriedade.

EXECUTANDO O COMANDO

Após criado o comando é necessário que executemos a operação! Para fazermos isso, temos 3 métodos em qualquer XXXCommand:

  • ExecuteNonQuery() - Método utilizado para executar comandos que não retornam resultados de busca. Como por exemplo inserção, deleção e atualização (INSERT, DELETE e UPDATE, respectivamente no SQL). O método em si retorna um inteiro que representa a quantidade de linhas modificadas no banco de dados após a sua execução;

  • ExecuteScalar() - Utilizado para executar comandos que retornam um único valor. Um exemplo prático é quando procuramos o nome de uma pessoa que tem CPF igual a 142312312-32, por exemplo. Mesmo que nosso comando SQL retorne mais de um comando, o método ExecuteScalar() irá retornar um object com o valor apenas da primeira coluna da primeira linha entre todos os valores retornados.

  • ExecuteReader() - Caso seja necessário retornar mais de um valor, poderemos usar esse método. O método executa o comando SQL no banco de dados e retorna os resultados em um objeto XXXDataReader. O XXXDataReader é um objeto forward-only e readonly que permite a visualização dos dados retornados. Discutirei o objeto XXXDataReader em outro artigo!

O USO DE PARÂMETROS

Trabalhando com strings SQL nós perceberemos que algumas vezes precisamos passar valores para os comandos que ainda não conhecemos. Para fazer coisas desse tipo nós usamos parâmetros. Queremos, por exemplo, inserir na tabela Cliente um novo registro. Se a tabela possuir como campos CPF e Nome, teríamos o seguinte código:

public void Inserir(string cpf, string nome) 
{
	//criando a conexao
	OleDbConnection conexao = null;
	try 
	{
	// inicializando
	OleDbConnection conexao = new OleDbConnection(strConecao);
	//criando o comando
	OleDbCommand comando = conexao.CreateCommand();
	//setando o CommandText e usando parâmetros na string de inserção
	comando.CommandText = "INSERT INTO Cliente VALUES(@cpf, @nome)";
	//criando os parâmetros e adicionando a coleção de parâmetros do comando
	comando.Parameters.Add("@cpf", cpf);
	comando.Parameters.Add("@nome", nome);

	//abrindo a conexão com o banco de dados
	conexao.Open();

	//executando o comando
	comando.ExecuteNonQuery();

	} 
	catch (Exception ex) 
	{
		//trata o erro
	}
	finally 
	{
		//fechando a conexao
		conexao.Close();
	}
}

Fiz questão de mostrar o código completo de um suposto método inserir para vocês verem coisas importantes que temos de lembrar:

  1. Cada comando tem uma coleção de parâmetros. Se vamos usar algum parâmetro, temos de adiciona-lo a essa coleção passando o nome do parâmetro (por exemplo, @cpf) seguido do objeto que representa o valor do parâmetro passado (por exemplo, a string cpf).

  2. É preciso abrir a conexão antes de executar qualquer comando!

  3. Para evitar erros futuros, é importante sempre fechar a conexão após o seu uso!

CONCLUSÃO

Bom pessoal, espero ter ajudado vocês a entenderem um pouco do uso de comandos para execução de operações no banco de dados no modelo conectado de acesso. No próximo artigo tratarei de uma visão inicial do modelo desconectado de acesso a banco e de implementação com DataSets, DataAdapters, etc. Até lá!


 

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
Ainda não existem comentários sobre este artigo. Seja o(a) primeiro(a)!
Outros artigos do autor Topo
Introdução a Orientação a Objetos - Parte 3
Introdução a Orientação a Objetos - Parte 2
Introdução a Orientação a Objetos
Acessando banco de dados em .NET – Parte 3 (final)
Acessando banco de dados em .NET
Multilingüagem na plataforma .NET
Uma discussão sobre tipos – boxing e unboxing em C#
Artigos relacionados Topo
Compactação de ViewState em ASP.NET - Parte 2 (Colocando na Session)
Escopo e nível de acessos no C#
Encriptando valores passados por QueryString
Array, ArrayList e List(T): O que devemos saber?
Truques em coleções com LINQ e C# 3.0 - Parte 1
Descubra os Delegates "Show de Bola"
Tratamento de excessões em aplicações N-Tier
Generics com C# e .NET 2.0
Explorando as Coleções do .NET Framework - Parte 2
Explorando as Coleções do .NET Framework - Parte 1
Explorando alguns Delegates do C# 2.0: Predicates, Converter, Comparison e Action
C# 4.0 - Tipos Dinâmicos
Delegates e eventos no C# 2.0 - Parte 2
Delegates e eventos no C# 2.0 - Parte 1
Compactação com GZipStream e DeflateStream
Resolva seus problemas do dia-a-dia com Elevate
Criando e Lendo Cookie
Avaliando regras de negócio dinamicamente em C#
Integrando sua Aplicação .Net com Twitter
C# 4.0
Adicionando Menu no DataGridView
Persistindo TreeView no Banco de Dados
MP3 player com DirectX
Mensagem em JavaScript com .NET
Reproduzindo mp3 no .NET com C#
Receitas para o fim de ano para empresas de software
Sobrecarga, Herança, Polimorfismo e Exceção em C#
Qual a razão para incentivar as comunidades técnicas?
Visual Studio e seus Containers
Comparativo de performance: LINQ, Lambda e Dynamic LINQ
Produtos relacionados Topo
Pacote: Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
Pacote: Promoção Linq To SQL (válido somente para pagamento via boleto bancário)
Livro: Programando C# 3.0 - 5º Edição
Livro: Crystal Reports 2008 - O Guia Completo
Livro: C# 2008 Para Leigos
Livro: Microsoft Visual C# 2008 Express Edition - Aprenda na Prática
CD/DVD: DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
Livro: Profissional C# e a Plataforma .NET 3.5 Curso Completo
Pacote: Pacote promocional Linq to SQL
CD/DVD: DVD de Treinamento E-Commerce com Visual Web Developer
Livro: Programando .NET 3.5
Livro: LINQ e C# 3.0 - A Solução em Consultas para Desenvolvedores
Livro: LINQ em Ação
CD/DVD: DVD de Treinamento - Crie uma aplicação ASP.NET com LINQ TO SQL
Livro: C# 3.0 Guia de Bolso
Livro: Desenvolvendo Information Cards e CardSpace: Do Iniciante ao Profissional
Livro: Desenvolvimento em Camadas com C# .NET
Livro: Use a Cabeça C#
Livro: LINQ Guia de Bolso
Livro: ASP.NET 2.0 Web Parts em Ação
CD/DVD: DVD de Treinamento Explorando o LINQ para SQL
CD/DVD: CD de Treinamento – Implementando AJAX em páginas ASP.NET 3.5 com o Visual Studio .NET 2008
Livro: Soa na Prática - A arte da modelagem de Sistemas Distribuídos
Livro: C# Guia de Consulta Rápida
Livro: Windows Presentation Foundation
Livro: Pro WF Windows Workflow no .NET 3
Livro: Como programar com ASP.Net e C#
CD/DVD: CD de Treinamento sobre ASP.NET 2.0 Básico
CD/DVD: CD de treinamento: Um mergulho no Controle GridView do ASP.NET 2.0
E-Book: Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Livro: Use a Cabeça! Padrões de Projetos (Design Patterns) 2 Edição
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 1.942
Artigos: 2.746
Cases: 14
Oportunidades: 4.185
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
Baixe o Visual Studio 2010 Beta
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Mobile (válido somente para pagamento via boleto bancário)
Promoção Mobile (válido somente para pagamento via boleto bancário)
De: R$ 239,00
Por: R$ 146,00
Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
De: R$ 162,00
Por: R$ 89,00
Promoção VSTS (válido somente para pagamento via boleto bancário)
De: R$ 219,00
Por: R$ 146,00
Promoção Linq To SQL (válido somente para pagamento via boleto bancário)
De: R$ 249,00
Por: R$ 156,00
Promoção ASP.Net com Banco de Dados (válido somente para pagamento via boleto bancário)
De: R$ 249,00
Por: R$ 146,00
CDs
DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
De: R$ 83,00
Por: R$ 73,00
Curso completo de MySQL
Por: R$ 89,00
DVD de Treinamento - ISA Server 2006 - Implementação
De: R$ 83,00
Por: R$ 73,00
CD de Treinamento Adobe Photoshop CS4 Extended – 3D Arte
De: R$ 83,00
Por: R$ 53,00
DVD de Treinamento - Recursos avançados do Windows Mobile 6
De: R$ 83,00
Por: R$ 73,00
Livros
Aprendendo SQL
Aprendendo SQL
Por: R$ 83,00
Web Services SOAP em Java
Novatec
Por: R$ 42,00
Guia Mangá de Bancos de Dados
Novatec
Por: R$ 39,00
Guia Mangá de Estatística
Novatec
Por: R$ 39,00
Guia Mangá de Eletricidade
Novatec
Por: R$ 39,00
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Anderson Patricio
Ramon Durães
Robert Martim
Fernando Amaral
Eric C M Oliveira
Marcio Franco
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
SAP Business One - Implementação e Localização para o Brasil – Overview
PL/SQL - Procedures e Funções
ASP.NET 2.0 - Explorando o GridView
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
PHP: Upload de imagens com segurança
Nota Fiscal Eletrônica - Geração, Assinatura e Transmissão
Criando aplicativos para o Orkut
Instalando Apache + MySQL + PHP 5 no Windows