| Posted by Mladen Gogala on 06/15/97 11:48 
rich wrote:> I am building a database and I am using a list where I can make
 > multiple choices.  The data is like this
 >
 > Master table
 > item1id
 > item2
 > index(item1id)
 >
 > detail table
 > item1id
 > item2id
 > index (item1id, item2id)
 >
 > item2 table
 > item2id
 > item2
 > index(item2id)
 >
 > My form would have
 >
 > Item1
 >
 > list of all the choices for item2 table where I can make multiple
 > choices.
 >
 > This piece is easy enough to do inserts with.  Loop on the listbox
 > array and insert.
 > Now the question is what do I do to:
 > 1. Make changes
 > 2. Delete an item.
 >
 > Do I instead of update, build a function where I delete all the items
 > in the detail table belonging to item1 and then insert the new list?
 > Or is there a more elegant way to handle this?
 >
 
 Nope, you should just define the foreign key with "ON DELETE CASCADE"
 option. You should do something like:
 
 ALTER TABLE DETAIL ADD CONSTRAINT FK_MASTER_DETAIL
 FOREIGN KEY(ITEM1) REFERENCES MASTER(ITEM1) ON DELETE CASCADE;
 
 This is how it works on the known EMP and DEPT tables:
 
 SQL> alter table emp add constraint fk_dept_emp
 2  foreign key(deptno) references dept(deptno) on delete cascade;
 
 Table altered.
 
 SQL>
 
 --
 Mladen Gogala
 http://www.mgogala.com
  Navigation: [Reply to this message] |