Funções para buscar informações nas tabelas
O API da Preactor possui funções para facilitar a vida do programar ao buscar alguma informação dentro das tabelas do Preactor. Por exemplo, quando queremos identificar uma ordem pelo seu Número, ou pelo recurso que ela está alocado, ou mesmo buscar todas as operações de uma ordem.
Creio que essa função sem sombra de dúvidas é a mais utilizada ao se trabalhar com Preactor.
preactor.FindMatchingRecord("TABELA","CAMPO", posição, ValorBuscado);
Sobregarca:
preactor.FindMatchingRecord("TABELA", "CAMPO", posição, ValorBuscado, SearchDirection.Backwards);
A função básica possui 4 parâmetros:
- Tabela: "Apontamento";
- Campo ou Field: "Ordem";
- Posição, ou a partir de qual posição dentro da fila você deseja buscar sua informação: posição ou record ;
- Valor: valor a ser buscado, pode ser uma string, double, date, int bool;
- O quinto parâmetro da sobrecarga indica a direção de sua busca, "SearchDirection.Forwards" você quer buscar a informação do início da fila para o final, ou "SearchDirection.Backwards" do final da fila para o início;
Veja o exemplo abaixo onde iremos procurar dentro da tabela de Apontamento uma ordem A001:
public int Run(ref PreactorObj preactorComObject, ref object pespComObject)
{
IPreactor preactor = PreactorFactory.CreatePreactorObject(preactorComObject);
var ordem = "A001";
int record = preactor.FindMatchingRecord("Apontamento", "Ordem", 0, ordem);
if (record > 0)
{
MessageBox.Show("A ordem: " + ordem + " foi encontrada, registro núm. " + record);
return 0;
}
MessageBox.Show("A ordem " + ordem + " não foi encontrada!");
return 0;
}
Infelizmente esse método se resumo a buscar apenas um valor em um campo, ele não funciona também para buscarmos um trecho de uma string dentro de outra.Quando precisamos buscar dois campos em uma tabela, efetuamos uma busca por um campo (ex: Recurso), em seguida lemos os valores do outro campo( ex: Ordem), aí se encontrarmos o que procuramos saímos da função e retornamos o resultado.
Veja esse exemplo em que buscamos os registros que possuem o Recurso: "Packing Line 1" e que o campo ordem possua o valor "A001":
public int Run(ref PreactorObj preactorComObject, ref object pespComObject)
{
IPreactor preactor = PreactorFactory.CreatePreactorObject(preactorComObject);
var recurso = "Packing Line 1";
int record = preactor.FindMatchingRecord("Apontamento", "Ordem", 0, recurso);
while (record > 0)
{
var ordem = preactor.ReadFieldString("Apontamento", "Ordem", record);
if(ordem == "A001")
break;
//VEJA QUE A PRÓXIMA BUSCA SERÁ A PARTIR DO REGISTRO "RECORD"
record = preactor.FindMatchingRecord("Apontamento", "Ordem", record, recurso);
}
if (record > 0)
{
MessageBox.Show("O recurso " + recurso + " e a ordem A001 possuem o registro " + record);
return 0;
}
MessageBox.Show("O recurso " + recurso + " e a ordem A001, não foram encontrados!");
return 0;
}
Uma observação, vale apena lembrar que o Preactor tem seus registros indexados como uma fila, por esse motivo, veja que no final do while, nós refazemos a busca a partir do registro "Record", sendo que "Record" nada mais é do que uma índice dentro da fila.WorkShop 02
Para o workshop 02 faça download do modelo (Clique aqui para Download).Importe o arquivo CSV AtualizaOrdens.csv que está contido na pasta Import-Export Files do modelo. Busque na tabela de "Apontamento" os registros das ordens que estão contidas no arquivo CSV e atualize o nome do Recurso e o Status, se o Status do arquivo for "finalizada", você deverá excluir o registro da tabela de Apontamento.
Mãos a obra.
Resposta do workShop 02
Nenhum comentário:
Postar um comentário