Conjunto de registros: parametrizando um conjunto de registros (ODBC)
Este tópico se aplica às classes ODBC do MFC.
Às vezes talvez você queira poder selecionar em tempo de execução registros, usando as informações que você calculados ou obtido do usuário final. Os parâmetros do conjunto de registros permitem executar essa meta.
Este tópico explica:
A finalidade de um conjunto de registros com parâmetros.
Quando e como você pode optar por parametrizar um conjunto de registros.
Como declarar o parâmetro os membros de dados no conjunto de registros classificação.
Como transmitir informações de parâmetro a um conjunto de registros objeto em tempo de execução.
Conjuntos de registros com parâmetros
Um conjunto de registros com parâmetros permite passar em tempo de execução informações de parâmetro. Isso tem dois efeitos valiosos:
Pode resultar em um melhor velocidade de execução.
Permite a você criar em tempo de execução uma consulta, com base nas informações não disponível em tempo de design, como as informações obtidas do usuário ou calculada em tempo de execução.
Quando você chama Abrir para executar a consulta, o conjunto de registros usa as informações de parâmetro para concluir a instrução de SQL SELECT . É possível parametrizar todo o conjunto de registros.
Quando usar parâmetros
Os usos típicos de parâmetros incluem:
Passando argumentos de tempo de execução para uma consulta predefinida.
Para passar parâmetros para um procedimento armazenado, você deve especificar uma instrução personalizado completo ODBC CALL — com os espaços reservados de parâmetros — quando você chama Abrir, substituindo a instrução SQL padrão do conjunto de registros. Para obter mais informações, consulte CRecordset::Openna referência da biblioteca de classes e SQL: Personalizando a instrução SQL do conjunto de registros (ODBC) e Conjunto de registros: Declarando uma classe para uma consulta predefinido (ODBC).
Eficientemente executando repete tanto com informações de parâmetro diferente.
Por exemplo, a cada vez que o usuário final pesquisa informações para um aluno específico na base de dados do registro do aluno, você pode especificar o nome ou a ID do estudante como um parâmetro obtido do usuário. Então, quando você chama a função de membro de Requery do conjunto de registros, a consulta seleciona apenas que o registro do aluno.
A cadeia de caracteres de filtro do conjunto de registros, armazenada em m_strFilter, pode ter esta aparência:
"StudentID = ?"
Suponha que você obtém a ID do estudante em strInputIDvariável. Quando você define um parâmetro a strInputID (por exemplo, a ID 100 do estudante) o valor da variável é associado ao espaço reservado para o parâmetro representado por “?” na cadeia de caracteres do filtro.
Atribuir o valor de parâmetro como segue:
strInputID = "100"; ... m_strParam = strInputID;
Você não pode desejar configurar uma cadeia de caracteres de filtro da seguinte maneira:
m_strFilter = "StudentID = 100"; // 100 is incorrectly quoted // for some drivers
Para uma discussão sobre como usar aspas corretamente para cadeias de caracteres de filtro, consulte Conjunto de registros: Filtrando registros (ODBC).
O valor do parâmetro é diferente a cada vez que você você consulte novamente o conjunto de registros para uma nova ID do estudante
Dica
Usar um parâmetro é mais eficiente do que simplesmente um filtro.Para um conjunto de registros com parâmetros, o base de dados deve processar uma instrução SQL SELECIONAR apenas uma vez.Para um conjunto de registros filtrado sem parâmetros, a instrução de SELECIONAR deve ser processada cada vez que você Requery por um novo valor do filtro.
Para obter mais informações sobre filtros, consulte Conjunto de registros: Filtrando registros (ODBC).
A parametrização da classe do conjunto de registros
Dica
Esta seção é aplicada a objetos derivados de CRecordset no qual a busca de linhas do volume não foi implementado.Se você estiver usando a linha em massa que pesquisa, implemente parâmetros é um processo semelhante.Para obter mais informações, consulte Conjunto de registros: Buscando registros em massa (ODBC).
Antes de criar a sua classe do conjunto de registros, determine quais parâmetros, você precisa quais os tipos de dados são, e como o conjunto de registros usá-los.
Para parametrizar uma classe do conjunto de registros
Executar Assistente do consumidor MFC ODBC de Adicionar Classe para criar a classe.
Especificar membros de dados do campo para as colunas do conjunto de registros.
Depois que o assistente grava a classe em um arquivo em seu projeto, vá para o arquivo de .h e adicionar manualmente um ou mais membros de dados do parâmetro à declaração da classe. A adição de relatório poderia ser algo como o exemplo a seguir, parte de uma classe de instantâneo criado para responder à consulta “que os alunos são na classe superior?”
class CStudentSet : public CRecordset { // Field/Param Data CString m_strFirstName; CString m_strLastName; CString m_strStudentID; CString m_strGradYear; CString m_strGradYrParam; };
Adicionar seus membros de dados do parâmetro depois dos membros de dados gerados no campo. A convenção é anexar a palavra “Param” para cada nome de parâmetro definido pelo usuário.
Modifique a definição de função de membro de DoFieldExchange no arquivo .cpp. Adicionar uma chamada de função de RFX para cada membro de dados do parâmetro que você adicionou à classe. Para obter informações sobre como escrever suas funções de RFX, consulte Registre o campo for Exchange: Como funciona RFX. As chamadas de RFX para os parâmetros com uma única chamada para:
pFX->SetFieldType( CFieldExchange::param ); // RFX calls for parameter data members
No construtor da sua classe do conjunto de registros, incremente a contagem dos parâmetros, m_nParams.
Para obter mais informações, consulte Registre o campo for Exchange: Trabalhando com o código do assistente.
Quando você escreve o código que cria um objeto do conjunto de registros essa classe, coloque “?” símbolo de ponto de interrogação () em cada local nas cadeias de caracteres da instrução SQL no qual um parâmetro deve ser substituído.
Em tempo de execução, “?” os espaços reservados são preenchidos, em ordem, valores de parâmetro que você passa. O primeiro membro de dados do parâmetro definido após a chamada de SetFieldType substitui o primeiro “?” na cadeia de caracteres SQL, o segundo membro de dados do parâmetro substitui o segundo? “”, e assim por diante.
Dica
A ordem de parâmetros é importante: a ordem das chamadas de RFX para parâmetros na função de DoFieldExchange deve corresponder à ordem dos espaços reservados de parâmetros na cadeia de caracteres SQL.
Dica
A cadeia de caracteres mais provável a trabalhar é a cadeia de caracteres que você especifica (se houver) do membro de dados de m_strFilter da classe, mas alguns drivers ODBC podem permitir parâmetros em outras cláusulas do SQL.
Passando valores de parâmetro em tempo de execução
Você deve especificar valores de parâmetro antes de chamar Abrir (para um novo objeto do conjunto de registros Requery ) ou (para) existente.
Para passar valores para um conjunto de registros objeto em tempo de execução
Construir o objeto do conjunto de registros.
Preparar uma cadeia de caracteres ou mais cadeias de caracteres, como a cadeia de caracteres de m_strFilter , contendo a instrução SQL, ou partes delas. Colocar “?” os espaços reservados onde as informações de parâmetro ele será.
Atribuir um valor do parâmetro de tempo de execução para cada membro de dados do parâmetro do objeto.
Chame a função de membro de Abrir (ou Requery, para um conjunto de registros existente).
Por exemplo, suponha que você deseja especificar uma cadeia de caracteres de filtro para o conjunto de registros usando as informações obtidas em tempo de execução. Suponha que você construídas um conjunto de registros da classe CStudentSet anterior — rsStudentchamado — s e quer agora que você consulte novamente para um tipo específico de informações do aluno.
// Set up a filter string with
// parameter placeholders
rsStudents.m_strFilter = "GradYear <= ?";
// Obtain or calculate parameter values
// to pass--simply assigned here
CString strGradYear = GetCurrentAcademicYear( );
// Assign the values to parameter data members
rsStudents.m_strGradYrParam = strGradYear;
// Run the query
if( !rsStudents.Requery( ) )
return FALSE;
O conjunto de registros contém registros para os alunos cujos registros atendem às condições especificadas pelo filtro, que foi construído dos parâmetros de tempo de execução. Nesse caso, o conjunto de registros contém registros para todos os alunos superiores.
Dica
Se necessário, você pode definir o valor de um membro de dados do parâmetro como nulo, usando SetParamNull.É possível do mesmo modo verificar se um membro de dados do parâmetro é nulo, usando IsFieldNull.
Consulte também
Conceitos
Conjunto de registros: adicionando, atualizando e excluindo registros (ODBC)
Conjunto de registros: como conjuntos de registros selecionam registros (ODBC)