Como processar vários resultados através do DataReader no Visual C# .NET

Traduções de Artigos Traduções de Artigos
Artigo: 311274 - Ver produtos para os quais este artigo se aplica.
Expandir tudo | Reduzir tudo

Nesta página

Sumário

Este artigo contém uma função genérica que pode utilizar para processar vários conjuntos de registos e outras mensagens que são devolvidas a partir de procedimentos armazenados ou a execução de instruções de SQL de batch.

Descrição da técnica

ActiveX Data Objects (ADO) pode receber cinco tipos de dados do servidor:
  • Conjunto de registos
  • Número de registos que são modificados por uma consulta de acção (tal como INSERT, UPDATE, DELETE ou SELECT INTO)
  • Aviso ou mensagem informativa
  • Mensagem de erro
  • Procedimento armazenado devolvem valores e parâmetros de saída
Ao ler os resultados de uma secção de instrução de SQL, pode utilizar o método NextResult para posicionar DataReader no próximo resultado no conjunto de resultados.

Requisitos

A lista seguinte descreve o hardware recomendado, software, infra-estrutura de rede e service packs que necessita:
  • Microsoft Windows 2000 Professional, Windows 2000 Server, Windows 2000 Advanced Server ou Windows NT 4.0 Server
  • Microsoft Visual Studio .NET
  • Microsoft SQL Server 7.0 ou posterior
Este artigo pressupõe que está familiarizado com os seguintes tópicos:
  • Visual Studio .NET
  • Noções básicas do ADO.NET e sintaxe

Criar projecto e adicionar código

Este código de exemplo utiliza a tabela autores de pubs o servidor SQL da base de dados de exemplo.
  1. Cole as seguintes instruções SQL Query Analyzer ferramenta ou o utilitário ISQL:
    CREATE PROC MyProc
    AS
        SELECT * FROM Authors
        SELECT * FROM Authors WHERE State = 'CA'
    GO 
    					
  2. Inicie o Visual Studio NET..
  3. Crie um novo projecto de aplicação do Windows no Visual C# .NET. Form1 é adicionado ao projecto por predefinição.
  4. Certifique-se que o projecto contém uma referência ao espaço de nomes System.data e adicione uma referência a este espaço de nomes se não tiver.
  5. Colocar um botão de comando no Form1. Alterar a propriedade Name do botão para btnTest e alterar a propriedade de texto para teste .
  6. Utilize a instrução a utilizar espaços de nomes System.data.SqlClient , System.data.OLEDB e sistema para que não é necessário para qualificar declarações os espaços de nomes mais tarde no código. Adicione o seguinte código à secção General Declarations do Form1:
    using System;
    using System.Data.OleDb;
    using System.Data.SqlClient;
    					
  7. Adicione o seguinte código ao evento btnTest_Click :

    Nota Tem de alterar o valor de conta de ID de utilizador < nome de utilizador > para uma conta que tenha as permissões adequadas para efectuar estas operações na base de dados.
        String myConnString  = "User ID=<username>;password=<strong password>;Initial Catalog=pubs;Data Source=myServer";
        SqlConnection myConnection = new SqlConnection(myConnString);
        SqlCommand myCommand = new SqlCommand();
        SqlDataReader myReader ;
    
        myCommand.CommandType = CommandType.StoredProcedure;
        myCommand.Connection = myConnection;
        myCommand.CommandText = "MyProc";
        int RecordCount=0; 
    
        try
        {
            myConnection.Open();
    	myReader = myCommand.ExecuteReader();
    
    	while (myReader.Read())
    	{
     	    //Write logic to process data for the first result.
    	    RecordCount = RecordCount + 1;
    	}
    	MessageBox.Show("Total number of Authors: " + RecordCount.ToString());
    
    	myReader.NextResult();
    	RecordCount = 0;
    
    	while (myReader.Read())
    	{
    	    //Write logic to process data for the second result.
    	    RecordCount = RecordCount + 1;
    	}
    	MessageBox.Show("Authors from California: " + RecordCount.ToString());
        }
        catch(Exception ex) 
        {
           MessageBox.Show(ex.ToString());
        }
        finally
        {
    	myConnection.Close();
        }
    					
  8. Modificar a cadeia de ligação ( myConnString ) conforme apropriado para o ambiente.
  9. Guarde o projecto. No menu Debug , clique em Iniciar para executar o projecto.
  10. Clique em Testar . Repare que as caixas de mensagens de apresentam os dados que devolve o procedimento armazenado.

Referências

Para obter informações adicionais sobre chamar procedimentos armazenados, clique no número de artigo existente abaixo para visualizar o artigo na base de dados de conhecimento da Microsoft:
306574Como: chamada do SQL Server procedimentos armazenados no ASP.NET
Para obter informações adicionais sobre o tratamento de erros, clique no número de artigo existente abaixo para visualizar o artigo na base de dados de conhecimento da Microsoft:
308650Como obter erros de fornecedor subjacente utilizando o ADO.NET no Visual C# .NET
Para obter informações adicionais sobre parâmetros e procedimentos armazenados, clique no número de artigo existente abaixo para visualizar o artigo na base de dados de conhecimento da Microsoft:
308621PROBLEMA: Parâmetros de saída não são apresentados quando executa um comando ADO.NET no Visual C# .NET
Para obter mais informações sobre objectos ADO.NET e sintaxe, consulte o seguinte Microsoft .NET Framework Software Development Kit (SDK) documentação:
Acessando dados com o ADO.NET
http://msdn2.microsoft.com/en-us/library/e80y5yhx(vs.71).aspx

Propriedades

Artigo: 311274 - Última revisão: 13 de maio de 2007 - Revisão: 3.4
A informação contida neste artigo aplica-se a:
  • Microsoft ADO.NET (included with the .NET Framework)
  • Microsoft ADO.NET 1.1
  • Microsoft Visual C# .NET 2002 Standard Edition
  • Microsoft Visual C# .NET 2003 Standard Edition
Palavras-chave: 
kbmt kbhowtomaster kbsqlclient kbsystemdata KB311274 KbMtpt
Tradução automática
IMPORTANTE: Este artigo foi traduzido por um sistema de tradução automática (também designado por Machine translation ou MT), não tendo sido portanto revisto ou traduzido por humanos. A Microsoft tem artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais. O objectivo é simples: oferecer em Português a totalidade dos artigos existentes na base de dados do suporte. Sabemos no entanto que a tradução automática não é sempre perfeita. Esta pode conter erros de vocabulário, sintaxe ou gramática? erros semelhantes aos que um estrangeiro realiza ao falar em Português. A Microsoft não é responsável por incoerências, erros ou estragos realizados na sequência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza actualizações frequentes ao software de tradução automática (MT). Obrigado.
Clique aqui para ver a versão em Inglês deste artigo: 311274

Submeter comentários

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com