How to Prevent Duplicate Row Interactive Grid Oracle APEX
data:image/s3,"s3://crabby-images/b4337/b433793d4fcefa5828a598536cd8525511637db6" alt="" |
Preview gif |
Sometimes user wants to prevent duplicate row on that column where columns don't have a unique Id or Primary key Identification. On those cases here, I have provided a solution which will definitely help you.
- Create an editable Interactive Grid using the following query:
select ROWID,
EMPNO,
ENAME,
JOB,
DEPTNO
from EMP
data:image/s3,"s3://crabby-images/90d0c/90d0cd9d4a79e386b5d443815361becbbcf9164b" alt="" |
SQL Query |
- Create validation on the column on which you want to prevent duplicate rows. Select validation type (PL/SQL Function returning Error text), copy and paste bellow PLSQL code:
declare
l_count number;
begin
if :APEX$ROW_STATUS ='C' then -- You can use 'C' OR 'I'
select count(1) into l_count FROM EMP where EMPNO=:EMPNO;
end if;
if l_count>=1 then
return 'Employee Code '||:EMPNO||' is duplicate';
end if;
end;
data:image/s3,"s3://crabby-images/526f6/526f679648c366edfb3ebacce0435932f20985ad" alt="" |
Validation |
Very good Vikas. keep posting kind of blogs.
ReplyDelete