Slony-I 2.2.10 Documentation | ||||
---|---|---|---|---|
Prev | Fast Backward | Chapter 8. Schema schemadoc | Fast Forward | Next |
8.77. mergeset(p_add_id integer, p_set_id integer)
Function Properties
Language: PLPGSQL
Return Type: bigint
Generate MERGE_SET event to request that sets be merged together. Both sets must exist, and originate on the same node. They must be subscribed by the same set of nodes.declare v_origin int4; in_progress boolean; begin -- ---- -- Grab the central configuration lock -- ---- lock table sl_config_lock; -- ---- -- Check that both sets exist and originate here -- ---- if p_set_id = p_add_id then raise exception 'Slony-I: merged set ids cannot be identical'; end if; select set_origin into v_origin from sl_set where set_id = p_set_id; if not found then raise exception 'Slony-I: set % not found', p_set_id; end if; if v_origin != getLocalNodeId('_schemadoc') then raise exception 'Slony-I: set % does not originate on local node', p_set_id; end if; select set_origin into v_origin from sl_set where set_id = p_add_id; if not found then raise exception 'Slony-I: set % not found', p_add_id; end if; if v_origin != getLocalNodeId('_schemadoc') then raise exception 'Slony-I: set % does not originate on local node', p_add_id; end if; -- ---- -- Check that both sets are subscribed by the same set of nodes -- ---- if exists (select true from sl_subscribe SUB1 where SUB1.sub_set = p_set_id and SUB1.sub_receiver not in (select SUB2.sub_receiver from sl_subscribe SUB2 where SUB2.sub_set = p_add_id)) then raise exception 'Slony-I: subscriber lists of set % and % are different', p_set_id, p_add_id; end if; if exists (select true from sl_subscribe SUB1 where SUB1.sub_set = p_add_id and SUB1.sub_receiver not in (select SUB2.sub_receiver from sl_subscribe SUB2 where SUB2.sub_set = p_set_id)) then raise exception 'Slony-I: subscriber lists of set % and % are different', p_add_id, p_set_id; end if; -- ---- -- Check that all ENABLE_SUBSCRIPTION events for the set are confirmed -- ---- select isSubscriptionInProgress(p_add_id) into in_progress ; if in_progress then raise exception 'Slony-I: set % has subscriptions in progress - cannot merge', p_add_id; end if; -- ---- -- Create a SYNC event, merge the sets, create a MERGE_SET event -- ---- perform createEvent('_schemadoc', 'SYNC', NULL); perform mergeSet_int(p_set_id, p_add_id); return createEvent('_schemadoc', 'MERGE_SET', p_set_id::text, p_add_id::text); end;