Ver Mensaje Individual
  #1  
Antiguo 26-06-2007
Avatar de UREÑA
UREÑA UREÑA is offline
Miembro
 
Registrado: feb 2007
Posts: 75
Reputación: 18
UREÑA Va por buen camino
donde esta el error???

hola amigos!! lo que quiero hacer es lo siguiente:

tengo una tabla de materias, cada materia tiene su id que consta de 3 caracteres ejemplo. 001
tengo otra tabla que se llama Alu-Mat en la cual tengo un campo que se llama cursadas en cual se agrega el id de la materia que se curso ejemplo: 001002003 conforme se cursa una materia se le agregan 3 digitos que son el id de la materia al campo de cursadas

bueno lo que yo quiero es comparar el campo de cursadas con un id de la materia seleccionada en un combo y que me muestre el id del alumno(matricula) que no ha cursado esa materia

este es el codigo que tengo

espero haberme explicado gracias

Código SQL [-]
begin

  frm_DataModule.qry_AluMat_APM.Close;
  frm_DataModule.qry_AluMat_APM.SQL.Clear;
  frm_DataModule.qry_AluMat_APM.SQL.Add('SELECT ALUMNO.MATRICULA, ALU_MAT.CURSADAS FROM (ALUMNO INNER JOIN CALIFICACION ON ALUMNO.MATRICULA = CALIFICACION.MATRICULA) INNER JOIN ALU_MAT ON ALUMNO.MATRICULA = ALU_MAT.MATRICULA ');
  frm_DataModule.qry_AluMat_APM.SQL.Add('WHERE (((ALUMNO.AREA_ACADEMICA)='+VarToStr(combo_AA.keyvalue)+') AND ((CALIFICACION.ID_PERIODO) = '+QuotedStr(VarToStr(combo_Periodo.keyvalue))+'))');
  frm_DataModule.qry_AluMat_APM.SQL.Text;
  frm_DataModule.qry_AluMat_APM.Open;

  if frm_DataModule.qry_AluMat_APM.RecordCount <> 0 then
    begin
      incrementa := 0;
      while not (frm_DataModule.qry_AluMat_APM.eof) do
       begin
        cadena := frm_DataModule.qry_AluMat_APM.Fields[1].AsString;
        compara := Length(trim(cadena ));
        y := 1;
        incrementa := 0;
          for x := 0 to compara do
          begin
            cuatro := copy( cadena,y, 3 );
            y := y + 3;
            incrementa := incrementa +1;

            if cuatro = VarToStr(combo_Materia.KeyValue) then
            begin
              inc(z);
            end;

            if ((incrementa - 1 = compara) and (z = 1)) then
            begin
            ListBox1.Items.Add(frm_DataModule.qry_AluMat_APM.Fields[0].AsString);
            frm_DataModule.qry_AluMat_APM.next ;
            end ;
          end; //for end

       end; //while end

    end ;

end;
Responder Con Cita