Scroll to top

How to Run Async or One-way Long Running Database Processes Using OIC


Karan Tulsani - November 14, 2022

Reading Time: 5 minutes

In this blog, we will discuss DBMS job scheduler via Oracle Integration Cloud and how it can be accomplished.

DBMS SCHEDULER

This is a server-based scheduler, so everything is done in the context of the database server. It is nothing to do with scheduling things on a client PC.

Difference between DBMS_JOB and DBMS_SCHEDULER

DBMS_JOB DBMS_SCHEDULER
  • DBMS_JOB cannot schedule an O/S script.
  • DBMS_SCHEDULER can schedule O/S script.
  • It can only schedule jobs at first intervals.
  • It can use almost any schedule.
  • It does not keep history or log files in a database.
  • It keeps history and a copy of the log file in the database.

1.  What can the scheduler do?

The Scheduler supplies complex enterprise scheduling functionality, which you can use to:

  1. 1. Schedule job execution based on time or events.
  2. 2. Schedule job processing in a way that models your business requirements.
  3. 3. Manage and inspect jobs.
  4. 4. Execute and manage jobs in a clustered environment.

2. How does DBMS_SCHEDULER work?

  We can use DBMS_SCHEDULER in 3 separate ways.

  1. 1. First, we must define a program using PL/SQL or STORED PROCEDURE. (DBMS_SCHEDULER.CREATE_PROGRAM)
  2. 2. Next, we need to define a schedule for the above program.(DBMS_SCHEDULER.CREATE_SCHEDULE)
  3. 3. Finally, we need to create a job. Using the program name and schedule it uses the second step.(DBMS_SCHEDULER.CREATE_JOB)

dbms scheduler

3. How to create and run a job in Oracle?

  • A job is a collection of metadata that describes a user-defined task that is scheduled to run one or more time.
  • It is a combination of what needs to be executed(program) and when to run(schedule) along with any other arguments required by the program.
  • Job is completely self-contained depending on which overloaded of the CREATE_JOB procedure is used to create them.
  • Jobs are normally run asynchronously under the control of the job co-ordinator.

Note:  You must have the CREATE_JOB privilege to create a job in own schema and create any job privilege to create a job in any schema except SYS.

a.) 1. create_job

We can directly write a job which includes both program and schedule. No need to create program and schedule separately.

  dbms-3a

 

 a.) 2. For drop a job

Jobs can be dropped using the DROP_JOB procedure.

dbms-3a1

 

a.) 3. For disabling a job

Applicable jobs can be disabled using DISABLE procedure.

dbms-3a2

 

a.) 4. To enable a job

Applicable jobs can be enabled using ENABLE procedure.

dbms-enable a job

 

a.) 5. We can use the RUN procedure to start a job right away.

dbms-run job

 

a.) 6. To stop a running job, we can use the STOP procedure.

dbms-stop procedure

 

a.) 7. View schedule details

To see schedule details, you must use DBA_SCHEDULER_SCHEDULES query

dbms-3a6 

 

Note:  If we are not using Create job procedure, then we need to create program followed by schedule procedure separately.

b.) DBMS_SCHEDULER.create_program and program argument

dbms-3b

 

b.) 1. To drop a program

Program can be dropped by using the DROP procedure.

dbms-drop 

b.) 2. To disable a program

Program can be disabled by using DISABLE procedure.

dbms-3b2 

 

b.) 3. To enable a program

To enable a program, we can use ENABLE procedure.

dbms-3b3 

 

c.) DBMS_SCHEDULER.create_schedule

dbms-3c

Repeat interval using calendaring syntax

a.) Every day:

‘Freq= daily;’

b.) Every day, at midnight:

‘Freq=daily; by hour=0; by minute=0; by second=0;’

c.) Every day, at 06:00:

‘Freq=daily; by hour=6; by minute=0; by second=0;’

d.) Every hour:

Freq=hourly;

e.) Every hour, on the hour:

Freq=hourly; by minute=0; by second=0;

f.) Every minute:

Freq=minutely;

g.) Every Monday, at 09:00:

Freq=weekly; by day=Mon; by hour=9; by minute=0; by second=0;

h.) First Monday of each quarter:

Freq=monthly; by month=1,4,7,10; by day=1Mon;

Several types of job States:

  • Completed- Job completed not scheduled to run again.
  • Stopped- Job scheduled to run once and was stopped during its run.
  • Succeeded- Job scheduled to run once and completed successfully.
  • Failed- Job scheduled to run once and failed.
  • Running- Job is currently running.
  • Scheduled- Job is scheduled to be executed.
  • Disabled- Job is disabled.
  • Broken- Job is broken and has issues.

Why do we use DBMS_SCHEDULER via OIC?

Ans: We use the DBMS_SCHEDULER via OIC because, there is no need to wait for long running processes. OIC has a response time limit of four minutes. Also, it is reusable and easy to use. Also, it is reusable and easy to use.

Related article: How To Burst Large Data Files Using Chunk Or Split By From Oracle BI Report?

Problem: How to run a procedure from OIC to  Database

Solution: Steps to create OIC connection for DB adapter.

Step 1: Log in to the OIC Instance with valid credentials.

Step 2: Select DBaaS adapter under connection.

step2

 

Step 3: Supply all the necessary credentials to connect the adapter.

step3

 

Note: Before using the connection test it and save it.

Step 4: Add DB connection in the integration and select the operation as Invoke a stored procedure.

Add DB connection in the integration and select the operation as Invoke a stored procedure.

 

Step 5: Select the Schema name and choose the Procedure , which we create in Database.

step5

 

Step 6: Save the integration and test it.

step6

 

In this blog, we have successfully shared how to run and use a DBMS Scheduler via OIC. If you have any questions regarding this blog, you can get in touch with us at Conneqtion Group.

Karan Tulsani

Karan Tulsani is the Founder and CEO of Conneqtion Group, an Oracle Cloud Infrastructure (OCI) & Oracle SaaS Implementation Partner that helps customers achieve digital transformation in ERP and Analytics. He has extensive experience working with clients across Banking and Financial Services, FMCG, Supply Chain Management, and the Public Sector. Karan has successfully led and contributed to numerous consulting engagements, leveraging his deep expertise to deliver impactful solutions. Previously, he was part of the consulting teams at Evosys and Oracle, where he worked with clients across the NA, EMEA, and APAC regions.

Author avatar

Karan Tulsani

Karan Tulsani is the Founder and CEO of Conneqtion Group, an Oracle Cloud Infrastructure (OCI) & Oracle SaaS Implementation Partner that helps customers achieve digital transformation in ERP and Analytics. He has extensive experience working with clients across Banking and Financial Services, FMCG, Supply Chain Management, and the Public Sector. Karan has successfully led and contributed to numerous consulting engagements, leveraging his deep expertise to deliver impactful solutions. Previously, he was part of the consulting teams at Evosys and Oracle, where he worked with clients across the NA, EMEA, and APAC regions.

Related posts

Post a Comment

Your email address will not be published. Required fields are marked *