The Club
quinta-feira, 29 de julho 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
C# e Oracle
Por: Danielle Monteiro
[Entre em contato com o autor ]
Formada pela FATEC-SP, MCP (Microsoft Certified Professional), atua há 7 anos na área de desenvolvimento de sistemas.
Com grande experiência em VB.NET, C#, SQL Server (em diversas versões), Reporting Services 2005 e Oracle (também em diversas versões) é Analista de Sistemas da IT Group.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
C# e Oracle
Publicado em: 20/02/2008

Neste meu primeiro artigo resolvi falar de um assunto que pode dar trabalho para muitos desenvolvedores, o uso de C#/ VB.net usando uma base Oracle 9i.

O Framework 2005 apesar de maravilhoso, não possui suporte nativo (com a mesma eficiência e eficácia do suporte ao SQL Server 2005) ao Oracle. É necessário destacar que para o desenvolvimento deste tipo de sistemas é preciso baixar um provider específico para este fim o ODP.NET (disponível no site da Oracle http://www.oracle.com/technology/tech/windows/odpnet/index.html, onde podemos ter também informações muito úteis!!!)

Com o provider instalado e o projeto iniciado, além das referências default para acesso aos dados (System.Data e System.Data.Common) é preciso adicionar a seguinte referência ao projeto: Oracle.DataAccess.dll . Sem ela nada funciona!



Porque eu estou falando tudo isso?

O motivo é simples, há algumas diferenças fundamentais entre o Oracle e o SQL Server na manipulação dos dados, principalmente quando os comandos estão armazenados em Packages ou Stored Procedures.

Como a intenção não é promover uma comparação entre o Oracle 9.i e o SQL Server 2005, incluirei aqui somente os códigos usados para a manipulação de dados vindos do Oracle.

Exemplificarei aqui a Consulta de Dados já que no Oracle um select que retorna uma lista de dados tem algumas particularidades. As outras operações não têm muitas mudanças, mas podem ser assunto de uma continuação deste artigo...

Vamos começar pelos scripts...

1 - Usarei para este exemplo uma tabela simples chamada tbCliente:

Create Table tbCliente
 (ID NUMBER NULL,
  Nome VARCHAR2(100) NULL );
2 - Incluir dados na tabela criada:
insert into tbCliente (ID, Nome) values (1, 'Astrogildo')
insert into tbCliente (ID, Nome) values (2, 'Emengarda')
insert into tbCliente (ID, Nome) values (3, 'Rivadavia')
insert into tbCliente (ID, Nome) values (4, 'Elidieanildete')
3 - A package que servirá como base para o exemplo é a seguinte:
create or replace package pckCliente is
  	-- Public type declarations
/*Para retornar dados é preciso ter um tipo REF CURSOR declarado na package, 
porque os dados do select serão retornados em um objeto que possua este tipo */
  	TYPE T_CURSOR IS REF CURSOR;
	-- Procedures
/*É preciso ter um parâmetro de saída com o tipo T_Cursor, para que ele receba os dados.*/
	PROCEDURE spr_Cliente(cCursorDados out T_CURSOR);
end pckCliente ;

create or replace package body pckCliente is

/**************************************************************/
/**************************************************************/
/**************************************************************/
PROCEDURE spr_Cliente(cCursorDados out T_CURSOR)
   AS
        /* Criar uma variável do tipo T_Cursor.*/
    V_CURSOR T_CURSOR;
  begin
/* A variável V_Cursor receberá os dados da consulta.*/ 
open V_CURSOR for
      SELECT ID , Nome
        FROM tbCliente;
          /*Atribuir o valor da variável ao parâmetro de saída.*/ 
    cCursorDados := v_cursor;
  exception
	/*Variáveis de Manipulação de Exceções:
sqlcode = Variável que armazena o código de erro;
sqlerrm = variável que armazena a mensagem de erro*/ 
    when others then
      raise_application_error(-20999,
' Erro na consulta de Clientes! (Código do Erro: ' || sqlcode ||' // Descrição do Erro: ' || sqlerrm || ')');
END spr_Cliente;
/**************************************************************/
/**************************************************************/
/**************************************************************/
end pckCliente ;
Com a tabela criada e preenchida e com a package criada vamos ao código C#. Atenção aos comentários!

1º) Classe que faz acesso aos dados:
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.Common;
//Declarar a referência para a dll de data types do oracle
using Oracle.DataAccess.Types;
//Declarar a referência para o client do oracle
using Oracle.DataAccess.Client;

namespace Data
{
   public class Data
    {
        /// <summary>
        /// Esta rotina cria o objeto de conexão 
        /// </summary>
        /// <returns>OracleConnection</returns>
        public  OracleConnection GetConnection()
        {
            //String de Conexão
            string connection = "Data 
Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=dani)(PORT=1521)))
(CONNECT_DATA=(SERVICE_NAME=xe))); User Id=system; Password=dani";

            return new OracleConnection(connection);
        }


        /// <summary>
        /// Rotina que executa o comando
        /// <param name="pNomeCmd">Nome do comando que será executado</param>
        /// <param name="pParametros">parâmetros do comando</param>
        /// <returns>string</returns>
        /// </summary>
        /// 
        public DataTable ExecutaComando()
        {
            //Criar um objeto Oracle Connection
            OracleConnection cn = new OracleConnection();
            //Declarar um objeto Oracle Command
            OracleCommand dbCommand = cn.CreateCommand();
            //Criar um objeto DataTable
            DataTable oDt = new DataTable();

            //Atribuir à variável cn o Valor da função GetConnection
            cn = GetConnection();

            //Informar o nome do comando que será executado
            //Como estamos executando uma package devemos colocar
            //O nome da package seguido por um ponto e o nome da procedure
            dbCommand.CommandText = "pckCliente.spr_Cliente";
            //O tipo do comando é StoredProcedure
            dbCommand.CommandType = CommandType.StoredProcedure;
            
            //Criar o tratamento para 
            try
            {
                //A conexão que será usada é a que foi declarada no início do código
                dbCommand.Connection = cn;

                // Adicionar os parametros
                //**Procure preservar o mesmo nome do parâmetro e a mesma ordem em 
				//que ele está declarado na stored procedure**
            
                //Parâmetro de saída cCursorDados 
                //Pontos importantes:
                //O tipo do parâmetro deve ser obrigatóriamente RefCursor
                //Informar sempre a direção do parâmetro: Input, Output , InputOutPut, ReturnValue
                dbCommand.Parameters.Add(new OracleParameter("cCursorDados", 
OracleDbType.RefCursor, ParameterDirection.Output));

                //Criar um objeto Oracle Data Adapter
                OracleDataAdapter oDa = new OracleDataAdapter(dbCommand);

                //Preenchendo o DataTable
                oDa.Fill(oDt);

                //Resultado da Função
                return oDt;

                
            }
            catch (Exception ex)
            {
                if (cn.State == ConnectionState.Open)
                {
                    cn.Close();
                }
                dbCommand.Dispose();
                cn.Dispose();
                throw ex;
               
            }
            finally
            {
                if (cn.State == ConnectionState.Open)
                {
                    cn.Close();
                }
                dbCommand.Dispose();
                cn.Dispose();

            }
        }

    }
}
2º) Console que executa a rotina:
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
//Incluir a referência à classe Data
using Data;

namespace Artigo001_090108
{
    class Program
    {
        static void Main()
        {
           
            //Criar um objeto DataTable
            DataTable oDt = new DataTable();

            //Criar um objeto do tipo Data
            Data.Data obj = new Data.Data();

            //Preenchendo o DataTable
            oDt = obj.ExecutaComando();

            Console.WriteLine("Resultado Esperado para a Execução da Package:");
            //Fazendo o Loop nas linhas do DataTable
            foreach (DataRow linhas in oDt.Rows)
            {
                
                Console.WriteLine("ID: " + linhas["ID"].ToString() + " - Nome: " + linhas["Nome"].ToString());
                Console.WriteLine();

            }

            
        }
    }
}
3º) Resultado esperado:



Para finalizar:
  • O grande segredo é que o retorno de um comando select deve estar sempre em um parâmetro de saída;
  • O parâmetro de saída pode ser de diversos tipos, já que com o ODP.NET, teremos suporte a praticamente todos eles.
Quem quiser baixar o código é só clicar aqui!

Enfim, espero que este artigo tenha muita utilidade! Qualquer dúvida, crítica ou sugestão sintam-se a vontade para entrar em contato comigo no email Dani@wbsoft.com.br.

Abraços!





MS TechEd 2010



 

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
Parabéns pelo artigo, assim como me ajudou deve ter ajudado mtas outras pessoas tb!
Quem enviou: Antonio Carlos
Postado em: 15/3/2008 0:00:00
Muito legal o artigo. Bem explicado, exemplo bastante util...
Valeu mesmo !!!
Quem enviou: Anisio Fernandes
Postado em: 22/2/2008 0:00:00
Outros artigos do autor Topo
Cursores no Oracle – Parte 2 - OS LOOPs
Cursores no Oracle – Parte 1
Artigos relacionados Topo
Eval em C# com IronRuby
Trabalhando com CLR: Stored Procedure – Primeiro passo
Entendendo interfaces com C#
Executar aplicações em background com Agendador de Tarefas Windows
ExpandoObject: dinamismo no .NET 4.0
Integração C# + Ruby
Utilizando um Tipo T como parâmetro e recuperando seus valores
Detectando mudanças em objetos
URL Routing com o Visual Studio .NET 2010
Acessando dados com Textboxes e botões de navegação
Controle de Acesso Windows Forms C# - Parte 3
Trabalhando com SQL CLR: Início
Funcionalidades do Office usando Visual Studio for Office – Parte 3
Cadastro de um Consultório em Windows Forms, com C# e SQL Server – Parte 10
Carregar DataGridView utilizando linq to xml
Funcionalidades do Office usando Visual Studio for Office - Parte 2
Estenda as funcionalidades do Office com o Visual Studio for Office
A importância do StrongName
Cadastro de um Consultório em Windows Forms, com C# e SQL Server – Parte 9
Descubra o ADO.NET Entity Framework
Controle de Usuários – Windows Forms C# (Parte 2)
Por que utilizar StringBuilder?
Formatando String rapidamente
Resolvendo problemas combinatórios com LINQ
Introdução a Refatoração – Parte III
Controle de Usuários – Windows Forms C# (Parte 1)
Você gosta de compartilhar conhecimento?
Trabalhando com Procedures no .NET
Eventos: Um exemplo prático
Cadastro de um Consultório em Windows Forms, com C# e SQL Server – Parte 8
Produtos relacionados Topo
Pacote: Promoção C# Básico (válido somente para pagamento via boleto bancário)
CD/DVD: CD de Treinamento Criando Aplicações Asp.Net em Camadas (parte integrante do portal de vídeos .Net)
CD/DVD: CD de Treinamento - Aprenda C# Básico Passo a Passo
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)
CD/DVD: DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
CD/DVD: DVD de Treinamento E-Commerce com Visual Web Developer
CD/DVD: DVD de Treinamento - Crie uma aplicação ASP.NET com LINQ TO SQL
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
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)
E-Book: ASP.NET Ajax com C# e VB.NET (E-Book com entrega via download)
CD/DVD: CD de Treinamento - Desenvolvendo uma aplicação Smart Client com Visual Studio 2005, C#, Web Services e Banco de Dados
CD/DVD: CD de Treinamento sobre LINQ to SQL para iniciantes com Visual Studio .Net 2008
CD/DVD: CD de Treinamento sobre ADO.NET para Iniciantes
CD/DVD: CD de Treinamento Novidades das Linguagens C# 3.0 e VB 9 (Visual Basic 9)
CD/DVD: CD de Treinamento Introdução a .NET com C# - Visual Studio 2005
CD/DVD: CD ASP.NET 2.0 - Atualização Rápida (Visual Studio .NET 2005)
E-Book: E-Book: Lógica de Programação com C# e VB.NET (via download)
CD/DVD: CD - Treinamento de ASP.NET 2.0 AJAX Extensions
CD/DVD: CD de Treinamento de Visual Studio .NET 2005
CD/DVD: CD de Treinamento de ASP.NET 2.0 - Explorando as novidades
Livro: ASP.NET Utilizando C# - De Programador para Programador
E-Book: E-Book: Programando com C# e Visual Studio .NET 2005 (entrega via download)
E-Book: E-Book: Curso Prático de Visual Studio .NET 2005 (entrega via download)
E-Book: E-Book: Curso prático de Visual Studio .NET (via download)
Livro: Programando em C#.Net para Web: Guia Rápido Usando Visual Studio.Net 2003
CD/DVD: CD de Treinamento de Visual Studio .NET 2003 Multimídia
Livro: Gerenciamento de Projetos Guia do Profissional Vol. 1: Abordagem Geral e Definição de Escopo
© 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: 2.488
Artigos: 2.972
Cases: 14
Oportunidades: 4.546
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
O que você fará com o Visual Studio 2010?
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 com entrega via download (válido somente para pagamento via boleto bancário)
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
De: R$ 189,00
Por: R$ 126,00
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
De: R$ 149,70
Por: R$ 99,80
Promoção C# Básico (válido somente para pagamento via boleto bancário)
De: R$ 185,90
Por: R$ 136,00
Promoção PHP + MYSQL Intelimax (válido somente para pagamento via boleto bancário)
De: R$ 308,00
Por: R$ 219,00
Promoção Especial Infra
De: R$ 175,95
Por: R$ 136,00
CDs/DVDs
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
Por: R$ 59,00
DVD Curso de CorelDraw X4
Por: R$ 79,90
DVD Curso de Fireworks CS4
Por: R$ 49,90
DVD Curso de Indesign CS4
Por: R$ 55,00
DVD Curso de Efeitos Digitais
Por: R$ 49,90
Livros
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
De: R$ 129,00
Por: R$ 77,40
Foundation FLASH CS3 para Designers
Ciência Moderna
De: R$ 139,00
Por: R$ 83,40
Recursos Visuais na Web com PHP
Ciência Moderna
De: R$ 49,00
Por: R$ 29,40
Crie um Sistema Web com PHP 5 e AJAX - Controle de Estoque
Erica
De: R$ 99,50
Por: R$ 84,50
Crie Projetos Gráficos com Adobe Photoshop CS4, CorelDRAW X4 e Adobe InDesign CS4 - em Português
Erica
De: R$ 77,50
Por: R$ 65,80
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
Anderson Patricio
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Robert Martim
Ramon Durães
Alessandro de Oliveira Faria
José Carlos Macoratti
Eric C M Oliveira
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
Criando aplicativos para o Orkut
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
Excel: fórmulas matriciais
ASP.NET 2.0 - Explorando o GridView
Iniciando um projeto de Nota Fiscal Eletrônica - NFe
PL/SQL - Procedures e Funções
Excel: Comparando Listas
PHP: Formulários e upload de múltiplos arquivos e fotos