Friday, September 5, 2014

HRMS API: Create Person Address

DECLARE
   v_effective_date          DATE;
   v_person_id               NUMBER;
   v_primary_flag            VARCHAR2 (1);


   v_style                   VARCHAR2 (50);
   v_date_from               DATE;
   v_address_line1           VARCHAR2 (500);
   v_town_or_city            VARCHAR2 (50);
   v_region_1                VARCHAR2 (50);
   v_country                 VARCHAR2 (50);
   v_address_id              NUMBER;
   v_object_version_number   NUMBER;
   v_api_error               VARCHAR2 (500);
   v_error_msg               VARCHAR2 (500);
BEGIN
   v_primary_flag := 'Y';
   v_style := 'EG_GLB';
   v_country := 'EG';
   FOR i IN (SELECT *
               FROM xx_upload_addresses xx
              WHERE xx.accepted_flag = 'N' AND person_id IS NOT NULL)
   LOOP
      BEGIN
         SELECT per.effective_start_date, per.effective_start_date
           INTO v_date_from, v_effective_date
           FROM per_all_people_f per
          WHERE per.person_id = i.person_id
            AND per.effective_end_date = TO_DATE ('31/12/4712', 'DD/MM/YYYY');
         hr_person_address_api.create_person_address
                           (p_effective_date             => v_effective_date,
                            p_person_id                  => i.person_id,
                            p_primary_flag               => v_primary_flag,
                            p_style                      => v_style,
                            p_date_from                  => v_date_from,
                            p_address_line1              => i.building_en,
                            p_address_line2              => i.street_en,
                            p_address_line3              => i.sector_en,
                            p_town_or_city               => TRIM (i.town_en),
                            p_add_information13          => i.building_ar,
                            p_add_information14          => i.street_ar,
                            p_add_information15          => i.sector_ar,
                            p_add_information16          => TRIM (i.town_ar),
                            p_country                    => v_country,
                            p_address_id                 => v_address_id,
                            p_object_version_number      => v_object_version_number
                           );
         UPDATE xx_upload_addresses
            SET person_id = v_person_id,
                accepted_flag = 'Y',
                err_msg = 'Done',
                address_id = v_address_id
          WHERE employee_number = i.employee_number
            AND business_group_id = i.business_group_id;
      EXCEPTION
         WHEN OTHERS
         THEN
            v_date_from := NULL;
            v_effective_date := NULL;
            v_api_error := NULL;
            v_error_msg := NULL;
            v_api_error := SQLERRM;
            v_error_msg := v_error_msg || '   ' || v_api_error;
            UPDATE xx_upload_addresses
               SET err_msg = v_error_msg
             WHERE employee_number = i.employee_number
               AND business_group_id = i.business_group_id
               AND accepted_flag = 'N';
      END;
   END LOOP;
   COMMIT;
END;