-- -- Copyright (C) 2001, 2002 OpenForce, Inc. -- -- This file is part of dotLRN. -- -- dotLRN is free software; you can redistribute it and/or modify it under the -- terms of the GNU General Public License as published by the Free Software -- Foundation; either version 2 of the License, or (at your option) any later -- version. -- -- dotLRN is distributed in the hope that it will be useful, but WITHOUT ANY -- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS -- FOR A PARTICULAR PURPOSE. See the GNU General Public License for more -- details. -- create or replace trigger dotlrn_community_types_in_tr before insert on dotlrn_community_types for each row declare v_parent_sortkey dotlrn_community_types.tree_sortkey%TYPE; v_max_child_sortkey dotlrn_community_types.max_child_sortkey%TYPE; begin if :new.supertype is null then -- if this is the root community_type we leave it's sortkey as null return; else -- else get the max_child_sortkey of the parent community_type select tree_sortkey, max_child_sortkey into v_parent_sortkey, v_max_child_sortkey from dotlrn_community_types where community_type = :new.supertype for update of max_child_sortkey; end if; -- increment the sort_key v_max_child_sortkey := lpad(tree.increment_key(v_max_child_sortkey), 6, '0'); update dotlrn_community_types set max_child_sortkey = v_max_child_sortkey where community_type = :new.supertype; -- generate the sortkey for the current row :new.tree_sortkey := v_parent_sortkey || v_max_child_sortkey; end dotlrn_community_types_in_tr; / create or replace trigger dotlrn_communities_in_tr before insert on dotlrn_communities_all for each row declare v_parent_sortkey dotlrn_communities_all.tree_sortkey%TYPE; v_max_child_sortkey dotlrn_communities_all.max_child_sortkey%TYPE; begin if :new.parent_community_id is null then -- if this is the root community we get the sortkey from it's parent -- community_type select tree_sortkey, max_child_sortkey into v_parent_sortkey, v_max_child_sortkey from dotlrn_community_types where community_type = :new.community_type for update of max_child_sortkey; else -- else get the max_child_sortkey of the parent community_type select tree_sortkey, max_child_sortkey into v_parent_sortkey, v_max_child_sortkey from dotlrn_communities_all where community_id = :new.parent_community_id for update of max_child_sortkey; end if; -- increment the sort_key v_max_child_sortkey := lpad(tree.increment_key(v_max_child_sortkey), 6, '0'); if :new.parent_community_id is null then update dotlrn_community_types set max_child_sortkey = v_max_child_sortkey where community_type = :new.community_type; else update dotlrn_communities_all set max_child_sortkey = v_max_child_sortkey where community_id = :new.parent_community_id; end if; -- generate the sortkey for the current row :new.tree_sortkey := v_parent_sortkey || v_max_child_sortkey; end dotlrn_communities_in_tr; / show errors