sql >> Databasteknik >  >> RDS >> Oracle

Procedur för att kontrollera om det inte finns dubbletter av rader i tabellen innan du infogar (Oracle)

Du har ett semikolon efter ditt parameterblock och du saknar din IS eller AS klausul:

CREATE OR REPLACE PROCEDURE add_vals (c_cntry_id OUT COUNTRIES.COUNTRY_ID%TYPE,
                                       c_cntr_name IN COUNTRIES.COUNTRY_NAME%TYPE, 
                                       c_rgn_id IN COUNTRIES.REGION_ID%TYPE)
IS
BEGIN
  INSERT INTO countries(COUNTRY_ID, COUNTRY_NAME,REGION_ID)
    values (user_seq.nextval, c_cntr_name,c_rgn_id);
  c_cntry_id := user_seq.currval;
EXCEPTION
  WHEN dup_val_on_index
  THEN 
    c_cntry_id := null;
END;
/


  1. Möjliga PDOException-fel (MySQL 5)?

  2. Hur justify_hours() fungerar i PostgreSQL

  3. InsertAllOnSubmit infogar endast den första dataposten

  4. Hur använder man MAX() på ett delfrågeresultat?