sql >> Base de Datos >  >> RDS >> Oracle

Comprender Oracle Apex_Application.G_Fnn y cómo usarlo

Estás muy cerca.

select apex_item.checkbox2(10, empno) select_me,
apex_item.text(20, empno) empno,
apex_item.text(30, ename)||apex_item.hidden(50, empno) ename
from emp

Estoy concatenando el elemento oculto ya que no lo quiero en su propia columna. Interfiere con el diseño.
Además, el elemento oculto está allí debido a cómo funcionan las casillas de verificación. Las casillas de verificación solo envían sus valores para los elementos marcados. Esto significaría que la matriz 10 tiene 3 valores. Las otras matrices aún contendrían los valores para todas las filas.
Es por eso que agregué el empno oculto nuevamente:para que podamos hacer coincidir los valores marcados con las otras filas.

En el proceso de envío:

DECLARE
   v_empno emp.empno%TYPE; 
   v_ename emp.ename%TYPE;
BEGIN
   --f10: checkbox
   --f20: empno
   --f30: ename
   --f50: empno again
   for i in 1..apex_application.g_f10.count
   loop
      for j in 1..apex_application.g_f50.count loop
         if apex_application.g_f10(i) = apex_application.g_f50(j) 
         then         
            -- access values for the selected rows in the other arrays
            v_empno := apex_application.g_f20(j);
            v_ename := apex_application.g_f30(j);

            apex_debug_message.log_message('Employee: '||v_empno||' - '||v_ename);
         end if;
      end loop;
   end loop;
END;

Ejecute la página, habilite la depuración, seleccione los registros 2, 4 y 6, envíe.

Salida de depuración:

Todo lo que necesita hacer ahora es poner su procesamiento en ese ciclo.