sql >> Databáze >  >> RDS >> Oracle

Jak provést ověření řádek po řádku na formuláři Oracle APEX Tabular pomocí Ajax?

Jak bych to zkusil vyřešit. Všimněte si, že to nezahrnuje všechny (žádné?) eventuality nebo zpracování mnoha chyb. Budete to muset trochu upřesnit sami. např. jsem použil vstup pro selektor, budete potřebovat "vybrat". Pole se nemusí shodovat. Možná budete potřebovat úplně jiný selektor, například by td[headers]. Možná váš návratový objekt bude muset obsahovat jiné nebo více hodnot. Váš js možná bude potřebovat více rozšířit.
Nicméně by vám měl poskytnout dobrý základ pro začátek!

Javascript:

function validaterows(){
  var arrf01 = [], arrf02 = [];

  //fetch all the values from the source columns and put them in
  //a javascript array.
  $("input[name=f03]").each(function(){
    arrf01.push($v(this));
  });

  $("input[name=f04]").each(function(){
    arrf02.push($v(this));
  });

  //provide the constructed arrays to the on-demand process by using
  //the global f## arrays
  apex.server.process ( "MY_PROCESS", {
      f01: arrf01
    , f02: arrf02
  }, {
  , success: function( pData ) { 
      //pData should be an object, because jquery will have parsed the returned json-string
      apex.debug(pData);

      $.each(pData.validationArray, function(index, value){
        if ( value === 'INVALID' ) {
          // do something here when the result is invalid
          // maybe you want to color something red for example
          alert('The data at row '+index+' is not valid!');
        };
      });

      }
  } );
}

Proces plsql na vyžádání:

DECLARE
  l_return VARCHAR2(4000);
BEGIN
  FOR i IN apex_application.g_f01.count
  LOOP
    -- remember: the f## arrays are varchar arrays. Important for comparisons.
    -- Also take into account that the values could NOT be numeric at all.
    -- you'll probably want to run each value through an is-number check or else 
    -- you'll run into ORA errors
    IF to_number(apex_application.g_f01(i)) > to_number(apex_application.g_f02(i))
    THEN
      l_return := l_return || ',"INVALID"';
    ELSE
      l_return := l_return || ',"VALID"';
    END IF;
  END LOOP;

  IF l_return IS NOT NULL
  THEN
    -- create a json string 
    -- holds an object with 1 property (validationArray) with the value being
    -- an array holding a value for each row submitted
    l_return := '{"validationArray":['||LTRIM(l_return, ',')||']}';
  END IF;

  -- write the output to the buffer
  htp.p(l_return);
END;



  1. Jak předat výsledek mysql jako jSON přes ajax

  2. porovnání dvou kurzorů v oracle místo použití MINUS

  3. Zabezpečení pro připravený SQL příkaz s REGEX v dotazu

  4. Postgres vnořený v případě dotazu