pg_dbms_job
pg_dbms_job
pg_dbms_job : Extension to add Oracle DBMS_JOB full compatibility to PostgreSQL
Overview
| ID | Extension | Package | Version | Category | License | Language |
|---|---|---|---|---|---|---|
| 9260 | pg_dbms_job
|
pg_dbms_job
|
1.5 |
SIM
|
PostgreSQL
|
SQL
|
| Attribute | Has Binary | Has Library | Need Load | Has DDL | Relocatable | Trusted |
|---|---|---|---|---|---|---|
--s-d--
|
No
|
Yes
|
No
|
Yes
|
no
|
no
|
| Relationships | |
|---|---|
| Schemas | dbms_job |
| See Also | pg_cron
pg_task
pg_dbms_metadata
pg_dbms_lock
pgagent
pg_jobmon
oracle_fdw
orafce
|
Packages
| Type | Repo | Version | PG Major Compatibility | Package Pattern | Dependencies |
|---|---|---|---|---|---|
| EXT | PGDG
|
1.5 |
18
17
16
15
14
|
pg_dbms_job |
- |
| RPM | PGDG
|
1.5 |
18
17
16
15
14
|
pg_dbms_job_$v |
- |
| Linux / PG | PG18 | PG17 | PG16 | PG15 | PG14 |
|---|---|---|---|---|---|
el8.x86_64
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
el8.aarch64
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
el9.x86_64
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
el9.aarch64
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
el10.x86_64
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
el10.aarch64
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
PGDG 1.5
|
d12.x86_64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
d12.aarch64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
d13.x86_64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
d13.aarch64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
u22.x86_64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
u22.aarch64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
u24.x86_64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
u24.aarch64
|
MISS
|
MISS
|
MISS
|
MISS
|
MISS
|
| Package | Version | OS | ORG | SIZE | File URL |
|---|---|---|---|---|---|
pg_dbms_job_18 |
1.5 |
el8.x86_64 | pgdg | 26.8 KiB | pg_dbms_job_18-1.5-5PGDG.rhel8.x86_64.rpm |
pg_dbms_job_18 |
1.5 |
el8.aarch64 | pgdg | 26.7 KiB | pg_dbms_job_18-1.5-5PGDG.rhel8.aarch64.rpm |
pg_dbms_job_18 |
1.5 |
el9.x86_64 | pgdg | 26.0 KiB | pg_dbms_job_18-1.5-5PGDG.rhel9.x86_64.rpm |
pg_dbms_job_18 |
1.5 |
el9.aarch64 | pgdg | 26.0 KiB | pg_dbms_job_18-1.5-5PGDG.rhel9.aarch64.rpm |
pg_dbms_job_18 |
1.5 |
el10.x86_64 | pgdg | 26.6 KiB | pg_dbms_job_18-1.5-5PGDG.rhel10.x86_64.rpm |
pg_dbms_job_18 |
1.5 |
el10.aarch64 | pgdg | 26.6 KiB | pg_dbms_job_18-1.5-5PGDG.rhel10.aarch64.rpm |
| Package | Version | OS | ORG | SIZE | File URL |
|---|---|---|---|---|---|
pg_dbms_job_17 |
1.5 |
el8.x86_64 | pgdg | 26.6 KiB | pg_dbms_job_17-1.5-3PGDG.rhel8.x86_64.rpm |
pg_dbms_job_17 |
1.5 |
el8.aarch64 | pgdg | 26.5 KiB | pg_dbms_job_17-1.5-3PGDG.rhel8.aarch64.rpm |
pg_dbms_job_17 |
1.5 |
el9.x86_64 | pgdg | 26.1 KiB | pg_dbms_job_17-1.5-3PGDG.rhel9.x86_64.rpm |
pg_dbms_job_17 |
1.5 |
el9.aarch64 | pgdg | 26.1 KiB | pg_dbms_job_17-1.5-3PGDG.rhel9.aarch64.rpm |
pg_dbms_job_17 |
1.5 |
el10.x86_64 | pgdg | 26.6 KiB | pg_dbms_job_17-1.5-5PGDG.rhel10.x86_64.rpm |
pg_dbms_job_17 |
1.5 |
el10.aarch64 | pgdg | 26.5 KiB | pg_dbms_job_17-1.5-5PGDG.rhel10.aarch64.rpm |
| Package | Version | OS | ORG | SIZE | File URL |
|---|---|---|---|---|---|
pg_dbms_job_16 |
1.5 |
el8.x86_64 | pgdg | 26.6 KiB | pg_dbms_job_16-1.5-3PGDG.rhel8.x86_64.rpm |
pg_dbms_job_16 |
1.5 |
el8.aarch64 | pgdg | 26.5 KiB | pg_dbms_job_16-1.5-3PGDG.rhel8.aarch64.rpm |
pg_dbms_job_16 |
1.5 |
el9.x86_64 | pgdg | 26.1 KiB | pg_dbms_job_16-1.5-3PGDG.rhel9.x86_64.rpm |
pg_dbms_job_16 |
1.5 |
el9.aarch64 | pgdg | 26.0 KiB | pg_dbms_job_16-1.5-3PGDG.rhel9.aarch64.rpm |
pg_dbms_job_16 |
1.5 |
el10.x86_64 | pgdg | 26.6 KiB | pg_dbms_job_16-1.5-5PGDG.rhel10.x86_64.rpm |
pg_dbms_job_16 |
1.5 |
el10.aarch64 | pgdg | 26.6 KiB | pg_dbms_job_16-1.5-5PGDG.rhel10.aarch64.rpm |
| Package | Version | OS | ORG | SIZE | File URL |
|---|---|---|---|---|---|
pg_dbms_job_15 |
1.5 |
el8.x86_64 | pgdg | 26.3 KiB | pg_dbms_job_15-1.5-1.rhel8.x86_64.rpm |
pg_dbms_job_15 |
1.5 |
el8.aarch64 | pgdg | 26.2 KiB | pg_dbms_job_15-1.5-1.rhel8.aarch64.rpm |
pg_dbms_job_15 |
1.5 |
el9.x86_64 | pgdg | 25.8 KiB | pg_dbms_job_15-1.5-1.rhel9.x86_64.rpm |
pg_dbms_job_15 |
1.5 |
el9.aarch64 | pgdg | 25.7 KiB | pg_dbms_job_15-1.5-1.rhel9.aarch64.rpm |
pg_dbms_job_15 |
1.5 |
el10.x86_64 | pgdg | 26.6 KiB | pg_dbms_job_15-1.5-5PGDG.rhel10.x86_64.rpm |
pg_dbms_job_15 |
1.5 |
el10.aarch64 | pgdg | 26.5 KiB | pg_dbms_job_15-1.5-5PGDG.rhel10.aarch64.rpm |
| Package | Version | OS | ORG | SIZE | File URL |
|---|---|---|---|---|---|
pg_dbms_job_14 |
1.5 |
el8.x86_64 | pgdg | 26.3 KiB | pg_dbms_job_14-1.5-1.rhel8.x86_64.rpm |
pg_dbms_job_14 |
1.4.0 |
el8.x86_64 | pgdg | 26.0 KiB | pg_dbms_job_14-1.4.0-1.rhel8.x86_64.rpm |
pg_dbms_job_14 |
1.2.0 |
el8.x86_64 | pgdg | 25.2 KiB | pg_dbms_job_14-1.2.0-1.rhel8.x86_64.rpm |
pg_dbms_job_14 |
1.5 |
el8.aarch64 | pgdg | 26.2 KiB | pg_dbms_job_14-1.5-1.rhel8.aarch64.rpm |
pg_dbms_job_14 |
1.5 |
el9.x86_64 | pgdg | 25.8 KiB | pg_dbms_job_14-1.5-1.rhel9.x86_64.rpm |
pg_dbms_job_14 |
1.4.0 |
el9.x86_64 | pgdg | 25.6 KiB | pg_dbms_job_14-1.4.0-1.rhel9.x86_64.rpm |
pg_dbms_job_14 |
1.2.0 |
el9.x86_64 | pgdg | 24.8 KiB | pg_dbms_job_14-1.2.0-1.rhel9.x86_64.rpm |
pg_dbms_job_14 |
1.5 |
el9.aarch64 | pgdg | 25.7 KiB | pg_dbms_job_14-1.5-1.rhel9.aarch64.rpm |
pg_dbms_job_14 |
1.5 |
el10.x86_64 | pgdg | 26.6 KiB | pg_dbms_job_14-1.5-5PGDG.rhel10.x86_64.rpm |
pg_dbms_job_14 |
1.5 |
el10.aarch64 | pgdg | 26.6 KiB | pg_dbms_job_14-1.5-5PGDG.rhel10.aarch64.rpm |
Source
Install
Make sure PGDG repo available:
pig repo add pgdg -u # add pgdg repo and update cacheInstall this extension with pig:
pig install pg_dbms_job; # install via package name, for the active PG version
pig install pg_dbms_job -v 18; # install for PG 18
pig install pg_dbms_job -v 17; # install for PG 17
pig install pg_dbms_job -v 16; # install for PG 16
pig install pg_dbms_job -v 15; # install for PG 15
pig install pg_dbms_job -v 14; # install for PG 14Create this extension with:
CREATE EXTENSION pg_dbms_job;Usage
pg_dbms_job: Extension to add Oracle DBMS_JOB full compatibility to PostgreSQL
Enabling
CREATE EXTENSION pg_dbms_job;A dedicated scheduler daemon must be running per database:
pg_dbms_job -c /etc/pg_dbms_job/mydb-dbms_job.confSUBMIT - Schedule a Job
BEGIN;
-- Scheduled job: run a procedure every day
CALL dbms_job.submit(
job => jobid,
what => 'CALL my_procedure();',
next_date => current_timestamp + interval '1 minute',
interval => 'current_timestamp + ''1 day''::interval'
);
COMMIT;When next_date and interval are omitted, the job executes immediately and asynchronously.
BROKEN - Disable/Enable a Job
BEGIN;
CALL dbms_job.broken(12345, true); -- disable job
CALL dbms_job.broken(12345, false); -- re-enable job
COMMIT;CHANGE - Modify a Job
BEGIN;
CALL dbms_job.change(12345, null, null, 'current_timestamp + ''3 days''::interval');
COMMIT;INTERVAL - Change Execution Interval
BEGIN;
CALL dbms_job.interval(12345, 'current_timestamp + ''1 hour''::interval');
COMMIT;NEXT_DATE - Change Next Execution Date
BEGIN;
CALL dbms_job.next_date(12345, current_timestamp + interval '30 minutes');
COMMIT;WHAT - Change Job Code
BEGIN;
CALL dbms_job.what(12345, 'CALL new_procedure();');
COMMIT;REMOVE - Delete a Job
BEGIN;
CALL dbms_job.remove(12345);
COMMIT;RUN - Execute Immediately
CALL dbms_job.run(12345);Viewing Jobs
SELECT * FROM dbms_job.all_jobs;Execution History
SELECT * FROM dbms_job.all_scheduler_job_run_details;Last updated on