Total Pageviews

Friday, October 15, 2021

SQL function to get the employee schedule details

                               SQL function to get the employee schedule details

To get the employees availability as per their schedule using the below function:

TABLE(per_availability_details.get_schedule_details(p_resource_type => 'ASSIGN', p_resource_id => <assignment_id> ,p_period_start => <Start_date> ,p_period_end =>  <End_date> ))  

Example:

SELECT  

*

 FROM

TABLE(per_availability_details.get_schedule_details(p_resource_type => 'ASSIGN', p_resource_id => 300000008682319 ,p_period_start => to_date('17-10-2021','DD-MM-YYYY') ,p_period_end => to_date('23-10-2021','DD-MM-YYYY') ))  

WHERE 

availability_code = 'AVL'






Thanks

Sainath

Sunday, August 8, 2021

Global Transfer - HDL

                                                 Global Transfer - HDL

Termination of existing work relationship within a legal entity and creation of a new work relationship with a new legal entity is called as Global Transfer.

To do Global Transfer we need below 3 METADATAs:

1. Work Relationship

2. Work Terms (In New work relationship)

3. Assignment  (In New work relationship)

We should include GlobalTransferFlag as Y and an action code from the EMPL_GLB_TRANSFER action type in the new work relationship.

Here we don’t need to include the old WorkRelationship for termination, it will automatically be terminated. The termination date of the existing work relationship is one day before the start date of the new work relationship.

Note: (Need to check the Data consistency)

1.      Active an employee can’t be with a non-primary Work relationship.

2.      We can’t do the Global Transfer on the primary work relationship if the employee has two active work relationships. (Need to make the primary work relationship non-primary before doing the global transfer)

Hire Records:

METADATA|Worker|PersonNumber|StartDate|EffectiveStartDate|DateOfBirth|ActionCode

MERGE|Worker|Employee1|2018/01/01|2018/01/01|1992/06/17|HIRE

METADATA|PersonName|PersonNumber|EffectiveStartDate|LegislationCode|NameType|FirstName|MiddleNames|LastName

MERGE|PersonName|Employee1|2018/01/01|US|GLOBAL|S|N|R

METADATA|WorkRelationship|PersonNumber|DateStart|PrimaryFlag|LegalEmployerName|WorkerType

MERGE|WorkRelationship|Employee1|2018/01/01|Y|Legal_employer|E

METADATA|WorkTerms|AssignmentNumber|PersonNumber|LegalEmployerName|DateStart|EffectiveStartDate|EffectiveSequence|EffectiveLatestChange|ActionCode|PersonTypeCode|JobCode|WorkerType|BusinessUnitShortCode|SystemPersonType|AssignmentName|AssignmentType|AssignmentStatusTypeCode

MERGE|WorkTerms|ETEmployee1|Employee1|Legal_employer|2018/01/01|2018/01/01|1|Y|HIRE|Employee||E|Business_unit|EMP|Work_terms_Assign_name|ET|ACTIVE_PROCESS

METADATA|Assignment|AssignmentNumber|WorkTermsNumber|PersonNumber|LegalEmployerName|DateStart|EffectiveStartDate|EffectiveSequence|EffectiveLatestChange|ActionCode|PersonTypeCode|JobCode|BusinessUnitShortCode|WorkerType|SystemPersonType|AssignmentName|AssignmentType|AssignmentStatusTypeCode

MERGE|Assignment|EEmployee1|ETEmployee1|Employee1|Legal_employer|2018/01/01|2018/01/01|1|Y|HIRE|Employee||Business_unit|E|EMP|assignment_name|E|ACTIVE_PROCESS

 

Global Transfer records:

METADATA|WorkRelationship|PersonNumber|DateStart|PrimaryFlag|LegalEmployerName|WorkerType|GlobalTransferFlag

MERGE|WorkRelationship|Employee1|2019/05/10|Y|New_Legal_Employer|E|Y

METADATA|WorkTerms|AssignmentNumber|PersonNumber|LegalEmployerName|DateStart|EffectiveStartDate|EffectiveSequence|EffectiveLatestChange|ActionCode|PersonTypeCode|JobCode|WorkerType|BusinessUnitShortCode|SystemPersonType|AssignmentName|AssignmentType|AssignmentStatusTypeCode

MERGE|WorkTerms|ETEmployee1|Employee1|Legal_employer|2018/01/01|2019/05/10|1|Y|GLB_TRANSFER|Employee||E|Business_unit|EMP|Work_terms_Assign_name|ET|ACTIVE_PROCESS

METADATA|Assignment|AssignmentNumber|WorkTermsNumber|PersonNumber|LegalEmployerName|DateStart|EffectiveStartDate|EffectiveSequence|EffectiveLatestChange|ActionCode|PersonTypeCode|JobCode|BusinessUnitShortCode|WorkerType|SystemPersonType|AssignmentName|AssignmentType|AssignmentStatusTypeCode

MERGE|Assignment|EEmployee1|ETEmployee1|Employee1|Legal_employer|2018/01/01|2019/05/10|1|Y|GLB_TRANSFER|Employee||Business_unit|E|EMP|assignment_name|E|ACTIVE_PROCESS

 

 

Sunday, August 1, 2021

HDL File for Compensatory plan Balances Load

                                        HDL File for Compensatory plan Balances Load

To load the Compensatory plan balances use the below HDL.

The accrual Type for compensatory plans: ORA_ANC_COMPTME_DL

HDL: (PersonAccrualDetail.dat)

METADATA|PersonAccrualDetail|PersonNumber|WorkTermsNumber|PlanName|ProcdDate|AccrualType|Value
MERGE|PersonAccrualDetail|2345|ET2345|PlanName|2020/05/08|ORA_ANC_COMPTME_DL|1





Thanks

Sainath  

 

Thursday, July 22, 2021

The employment level entered is not eligible for the element Statutory Deductions Error

                  Error - Employment level entered is not eligible for the element Statutory Deductions


When hiring an employee if the below error occurs. Then we have to follow a few steps to avoid this error.

ERROR:

The message is ORA-20001: The employment level entered is not eligible for the element Statutory Deductions on YYYY-MM-DD. Details: You cannot grant the element to the payroll relationship, terms or assignment unless it meets the element eligibility criteria and has an element costing record. Ensure that a suitable element costing rule exists for the element, and that the eligibility criteria for a person matches those defined on the costing rule. ORA-06512: at "FUSION.PAY_ELEMENT_ENTRY_API", line 468 ORA-06512: at line 53 .

To avoid this error we have to follow the below steps:

1. Set up and maintenance --> Elements

2. Search for the "Statutory Deductions" Salary Element

3. Click on Statutory Deductions

4. Please make sure the effective as-of date is correct

4. Select "Element Eligibility" on the left-hand side and click on the Actions dropdown

5. Click on Create Element Eligibility

6. Fill in all the required information and submit.





Thanks

Sainath  

Wednesday, July 21, 2021

Credential sent Process to employees/Users in oracle cloud HCM

                              Credential sent Process to employees/Users in oracle cloud HCM


To send the credentials email notification or resend the welcome mail, need to follow the below steps:

1. Use the CredentialsEmailSent flag to No in User.dat HDL for the employees we want to send notifications to.

User.dat

METADATA|User|PersonNumber|CredentialsEmailSent

MERGE|User|1234|N

2. Run the schedule process "Send User Name and Password E-Mail Notifications"


To Stop credential email notification or sending welcome mail for the employees, need to follow the below steps:

1. Use the CredentialsEmailSent flag to Yes in User.dat HDL for the employees we want to stop notifications.

User.dat

METADATA|User|PersonNumber|CredentialsEmailSent

MERGE|User|1234|Y

2. Run the schedule process "Send User Name and Password E-Mail Notifications" which will send a notification to only Employees with CredentialsEmailSent set to N





Thanks

Sainath 

BIP Refresh Process

                                                             BIP Refresh Process


Login with a BI Administrator user and execute the following steps in order to clear the BI Cache:

1. Clear BI Publisher Cache:

Administration --> BI Publisher --> Manage BI Publisher --> System Maintenance --> Manage Cache --> Clear Object Cache

2. Clear cache for the integration between BI Publisher and OTBI

Administration-- > BI Publisher --> Manage BI Publisher --> Integration --> Oracle BI Presentation Services --> Clear the  BI Subject Area Metadata Cache

3. Clear OTBI Cache:

Administration-- > Issue SQL --> type :  "Call SAPurgeAllCache();" --> Click "Issue SQL" (you should see a message like "Operation SAPurgeAllCache succeeded!")

4. OTBI Reload Files and Metadata:

Administration-- > Maintenance and Troubleshooting --> Reload Files and Metadata

5. Logout --> Clear browser cache --> Restart browser

6. Login and retest  





Thanks

Sainath                                               

How to get Current User Person ID in Oracle cloud HCM SQL

                                        Current User Person ID - SQL


Below is the SQL to get the  login / Session user person Id in oracle cloud HCM :

HRC_SESSION_UTIL.GET_USER_PERSONID

Ex:

SELECT HRC_SESSION_UTIL.GET_USER_PERSONID FROM DUAL







Thanks

Sainath






Tuesday, July 20, 2021

SQL to get the UDT values

                                              SQL to get the UDT value

select

fuci.value

from

ff_user_tables fut

,ff_user_column_instances_f fuci

,ff_user_columns fuc

,ff_user_columns_tl fuct

,ff_user_rows_f furf

where 1=1

and fut.user_table_id = fuc.user_table_id

and fuc.user_column_id = fuct.user_column_id

and fut.user_table_id = furf.user_table_id

and fuci.user_row_id = furf.user_row_id

and fuci.user_column_id = fuct.user_column_id

and fut.BASE_USER_TABLE_NAME ='TABLE_NAME'

and fuct.USER_COLUMN_NAME IN ('COLUMN_NAME')

and furf.ROW_LOW_RANGE_OR_NAME IN ('ROW_NAMES')

--and to_number(:{PARAMETER.value})  between (cast(furf.ROW_LOW_RANGE_OR_NAME as float))  and furf.ROW_HIGH_RANGE

--and to_number(:{PARAMETER.value})  between furf.ROW_LOW_RANGE_OR_NAME and furf.ROW_HIGH_RANGE

order by furf.DISPLAY_SEQUENCE





Thanks

Sainath

Monday, July 19, 2021

Get UDT Information from SQL

                                            Get UDT(USER DEFINED TABLE) Information from SQL

 

UDT Table:

SELECT

 fut.user_table_name

,fut.base_user_table_name

,fut.range_or_match

,fut.user_key_units

,fut.user_table_id p_user_table_id

,ldg.name ldg_name

,'UserDefinedTable' metadata

FROM

 ff_user_tables_vl fut

,per_legislative_data_groups_vl ldg

WHERE 1=1

--AND fut.legislative_data_group_id = ldg.legislative_data_group_id

AND fut.user_table_id = :P_UDT

 

UDT Column:

SELECT

 fuc.user_column_name

,fuc.base_user_column_name

,fuc.data_type

,fuc.formula_id

,'UserDefinedTableColumn' metadata

FROM

 ff_user_columns_vl fuc

WHERE 1=1

AND fuc.user_table_id = :P_USER_TABLE_ID

 

 

 

UDT Rows:

SELECT

 fur.row_name

,fur.display_sequence

,TO_CHAR(fur.effective_start_date,'YYYY/MM/DD') row_effective_start_date

,TO_CHAR(fur.effective_end_date,'YYYY/MM/DD') row_effective_end_date

-- ,fur.row_high_range

-- ,fur.row_low_range_or_name

 

,DECODE(fut.range_or_match,'M','',fur.row_high_range)              row_high_range

,DECODE(fut.range_or_match,'M',fur.row_name,fur.row_low_range_or_name)              row_low_range_or_name

 

,'UserDefinedTableRow' metadata

FROM

ff_user_tables_vl fut

,ff_user_rows_vl fur

WHERE 1=1

AND fur.user_table_id = :P_USER_TABLE_ID

AND fut.user_table_id = fur.user_table_id

 

Column Instance:

SELECT

'UserDefinedTableColumnInstance' metadata

,fut.user_table_name

,fut.base_user_table_name

,fut.range_or_match

,fut.user_key_units

,display_sequence

,fur.row_name

,TO_CHAR(fur.effective_start_date,'YYYY/MM/DD') row_effective_start_date

,TO_CHAR(fur.effective_end_date,'YYYY/MM/DD') row_effective_end_date

,fur.row_high_range

,fur.row_low_range_or_name

,fuc.user_column_name

,fuc.base_user_column_name

,fuc.data_type

,fuc.formula_id

,fuci.value udt_value

,TO_CHAR(fuci.effective_start_date,'YYYY/MM/DD') col_inst_eff_start_date

,TO_CHAR(fuci.effective_end_date,'YYYY/MM/DD') col_inst_eff_end_date

FROM

 fusion.ff_user_tables_vl fut

,fusion.ff_user_columns_vl fuc

,fusion.ff_user_rows_vl fur

,fusion.ff_user_column_instances_f fuci

WHERE 1=1

--AND (fut.legislative_data_group_id = :P_LDG OR :P_LDG  IS NULL)

AND fut.user_table_id = :P_USER_TABLE_ID

AND fut.user_table_id = fuc.user_table_id

AND fut.user_table_id = fur.user_table_id

AND TRUNC(SYSDATE) BETWEEN fur.effective_start_date AND fur.effective_end_date

AND fuc.user_column_id = fuci.user_column_id

AND fur.user_row_id = fuci.user_row_id

AND TRUNC(SYSDATE) BETWEEN fuci.effective_start_date AND fuci.effective_end_date

 

Parameter(P_USER_TABLE_ID) LOV SQL for above SQL:

SELECT

user_table_name

,user_table_id

FROM

ff_user_tables_vl

 

UDT HDL Format Report:

 https://drive.google.com/file/d/1gnkepEqUgAQj657U0K20Owl-l_Ui4BZV/view?usp=sharing 





Thanks

Sainath

Wednesday, June 16, 2021

Query to fetch the bi report output destination details(Email- from mail, to mail, FTP- Server details and output name etc.)


with data as

(select distinct VALUE xmlval,requestid

from fusion_ora_ess.request_property_view

  where UPPER(NAME) = 'CONTROL_XML'),


 x as (select PARAMETER1,DEL_CHANNEL,Value,url.requestid,PARAMETER2,PARAMETER3,PARAMETER4,PARAMETER5,PARAMETER6,PARAMETER7,PARAMETER8

  from data d, 

       xmltable('/ROWSET/*' passing xmltype(d.xmlval) 

        columns

    PARAMETER1 varchar2(254) path 'PARAMETER1',

    PARAMETER2 varchar2(254) path 'PARAMETER2',

    PARAMETER3 varchar2(254) path 'PARAMETER3',

    PARAMETER4 varchar2(254) path 'PARAMETER4',

    PARAMETER5 varchar2(254) path 'PARAMETER5',

    PARAMETER6 varchar2(254) path 'PARAMETER6',

    PARAMETER7 varchar2(254) path 'PARAMETER7',

    PARAMETER8 varchar2(254) path 'PARAMETER8',

    DEL_CHANNEL varchar2(254) path 'DEL_CHANNEL'),

    fusion_ora_ess.request_property_view url

    where

    url.requestid = d.requestid

    --and url.requestid = '457286'

    and url.name = 'report_url'

   

    )

 

    select * from x where DEL_CHANNEL <> 'DB'


Tuesday, May 18, 2021

 

Delete bank accounts HDL – SQL

To delete the bank accounts, we need to delete :

1.       Personal Payment Methods

2.       External Bank Accounts

Personal Payment Methods delete HDL – SQL:

Select HDL from (

Select

('METADATA|PersonalPaymentMethod|PersonalPaymentMethodId|EffectiveStartDate|EffectiveEndDate|LegislativeDataGroupId|OrganizationPaymentMethodId') HDL, 1 as no

from dual

Union

(

SELECT

('DELETE'||'|'||

'PersonalPaymentMethod'||'|'||

PAY.PERSONAL_PAYMENT_METHOD_ID||'|'||

TO_CHAR(PAY.EFFECTIVE_START_DATE,'YYYY/MM/DD')||'|'||

TO_CHAR(PAY.EFFECTIVE_END_DATE,'YYYY/MM/DD')||'|'||

PAY.LEGISLATIVE_DATA_GROUP_ID||'|'||

PAY.ORG_PAYMENT_METHOD_ID) HDL,

2 as no

from

PER_ALL_PEOPLE_F P,

PER_ALL_ASSIGNMENTS_F A,

PAY_PERSON_PAY_METHODS_F PAY,

PAY_PAY_RELATIONSHIPS_DN P2,

PAY_PAYROLL_ASSIGNMENTS P3

 

where 1=1

AND P.PERSON_ID = A.PERSON_ID

AND A.ASSIGNMENT_STATUS_TYPE IN ('ACTIVE')

AND A.ASSIGNMENT_TYPE IN ('E','C')

AND P2.PAYROLL_RELATIONSHIP_ID = P3.PAYROLL_RELATIONSHIP_ID

AND P3.HR_ASSIGNMENT_ID = A.ASSIGNMENT_ID

AND PAY.PAYROLL_RELATIONSHIP_ID = P2.PAYROLL_RELATIONSHIP_ID

AND SYSDATE BETWEEN A.EFFECTIVE_START_DATE AND A.EFFECTIVE_END_DATE

AND SYSDATE BETWEEN P.EFFECTIVE_START_DATE AND P.EFFECTIVE_END_DATE

AND SYSDATE BETWEEN P2.START_DATE AND P2.END_DATE

AND SYSDATE BETWEEN P3.START_DATE AND P3.END_DATE

AND SYSDATE BETWEEN PAY.EFFECTIVE_START_DATE AND PAY.EFFECTIVE_END_DATE

AND P.PERSON_NUMBER IN('121')

)

)

order by no

 

External Bank Accounts delete HDL – SQL:

Select HDL from (

Select

('METADATA|ExternalBankAccount|ExternalBankAccountId') HDL, 1 as no

from dual

Union

(

SELECT

('DELETE'||'|'||

'ExternalBankAccount'||'|'||

BA.BANK_ACCOUNT_ID) HDL,

2 as no

 

from

 

PER_ALL_PEOPLE_F P,

PER_ALL_ASSIGNMENTS_F A,

PAY_PERSON_PAY_METHODS_F PAY,

PAY_PAY_RELATIONSHIPS_DN P2,

PAY_PAYROLL_ASSIGNMENTS P3,

PAY_BANK_ACCOUNTS BA

 

where 1=1

AND P.PERSON_ID = A.PERSON_ID

AND A.ASSIGNMENT_STATUS_TYPE IN ('ACTIVE')

AND A.ASSIGNMENT_TYPE IN ('E','C')

AND P2.PAYROLL_RELATIONSHIP_ID = P3.PAYROLL_RELATIONSHIP_ID

AND P3.HR_ASSIGNMENT_ID = A.ASSIGNMENT_ID

AND PAY.PAYROLL_RELATIONSHIP_ID = P2.PAYROLL_RELATIONSHIP_ID

AND SYSDATE BETWEEN A.EFFECTIVE_START_DATE AND A.EFFECTIVE_END_DATE

AND SYSDATE BETWEEN P.EFFECTIVE_START_DATE AND P.EFFECTIVE_END_DATE

AND SYSDATE BETWEEN P2.START_DATE AND P2.END_DATE

AND SYSDATE BETWEEN P3.START_DATE AND P3.END_DATE

AND SYSDATE BETWEEN PAY.EFFECTIVE_START_DATE AND PAY.EFFECTIVE_END_DATE

AND PAY.BANK_ACCOUNT_ID = BA.BANK_ACCOUNT_ID

AND P.PERSON_NUMBER IN('121')        

)

)

order by no

 

Wednesday, March 17, 2021

 

SQL to get the document from UCM server

To access the documents from UCM we need the Attachments Administrator role.

We can download the documents, which we are uploaded in Document of Records, Profiles etc.,

From the below SQL we can get we can get the URL’s to download the documents:

SELECT

papf.person_number,

ppnf.first_name,

ppnf.last_name,

fdt.file_name,

fdt.dm_version_number document_id,

fdt.dm_document_id UCM_file,

'https://'|| (SELECT EXTERNAL_VIRTUAL_HOST INSTANCE_NAME FROM FUSION.ASK_DEPLOYED_DOMAINS WHERE DEPLOYED_DOMAIN_NAME ='FADomain')||'/cs/idcplg?IdcService=GET_FILE'||'&dID='

|| fdt.dm_version_number

||'&'||'dDocName='

|| fdt.dm_document_id

|| '&'||'allowInterrupt=1'  UCM_file_link ,

fad.entity_name

FROM

per_all_people_f papf,

per_person_names_f ppnf,

HR_DOCUMENTS_OF_RECORD hpb,

fnd_attached_documents fad,

fnd_documents_tl fdt

WHERE

1=1

AND hpb.person_id = papf.person_id

AND papf.person_id = ppnf.person_id

AND hpb.DOCUMENTS_OF_RECORD_ID = fad.pk1_value

AND fad.document_id = fdt.document_id

AND fdt.language = 'US'

--AND fad.entity_name = 'HR_DOCUMENTS_OF_RECORD' --HRT_PROFILES_B

AND ppnf.name_type = 'GLOBAL'

AND trunc(sysdate) between papf.effective_start_date and papf.effective_end_date

AND trunc(sysdate) between ppnf.effective_start_date and ppnf.effective_end_date

Enable Advanced Edit in HCM Extracts- After 24A update

 Enable Advanced Edit in HCM Extracts- After 24A update After 24A update Oracle deprecated the advanced edit in HCM Extracts. To Enable the ...