sipd-transaksi-master/migrations/000008_create_penugasan_penyelia_skpd_table.up.sql
2025-09-16 08:42:27 +07:00

40 lines
3.2 KiB
SQL

CREATE TABLE IF NOT EXISTS public.penugasan_penyelia_skpd (
id_unik_penugasan_penyelia_skpd uuid DEFAULT public.uuid_generate_v7() NOT NULL,
tahun integer DEFAULT 0 NOT NULL,
id_daerah integer DEFAULT 0 NOT NULL,
id_unik_pegawai uuid DEFAULT '00000000-0000-0000-0000-000000000000' NOT NULL,
id_unik_skpd uuid DEFAULT '00000000-0000-0000-0000-000000000000' NOT NULL,
id_unik_sub_skpd uuid DEFAULT '00000000-0000-0000-0000-000000000000' NOT NULL,
created_at timestamp(6) without time zone DEFAULT now() NOT NULL,
created_by integer DEFAULT 0 NOT NULL,
updated_at timestamp(6) without time zone DEFAULT '0001-01-01 00:00:00'::timestamp without time zone NOT NULL,
updated_by integer DEFAULT 0 NOT NULL,
deleted_at timestamp(6) without time zone DEFAULT '0001-01-01 00:00:00'::timestamp without time zone NOT NULL,
deleted_by integer DEFAULT 0 NOT NULL
);
ALTER TABLE public.penugasan_penyelia_skpd ADD CONSTRAINT penugasan_penyelia_skpd_pkey PRIMARY KEY (id_unik_penugasan_penyelia_skpd, tahun, id_daerah);
ALTER TABLE public.penugasan_penyelia_skpd ADD CONSTRAINT penugasan_penyelia_skpd_unique_key UNIQUE (tahun, id_daerah, id_unik_pegawai, id_unik_skpd, id_unik_sub_skpd);
COMMENT ON TABLE public.penugasan_penyelia_skpd IS 'Tabel berisi penugasan mitra perangkat daerah pada pegawai (staf) tim TAPD.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.id_unik_penugasan_penyelia_skpd IS 'ID unik UUID sebagai ID primary key.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.tahun IS 'Tahun anggaran.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.id_daerah IS 'ID Pemerintah daerah.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.id_unik_pegawai IS 'ID pegawai dari staf yang ditugaskan.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.id_unik_skpd IS 'ID SKPD induk yang membawahi pelaksana kegiatan.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.id_unik_sub_skpd IS 'ID SKPD pelaksana kegiatan.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.created_at IS 'Tanggal dan waktu data dibuat.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.created_by IS 'ID pengguna yang membuat data.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.updated_at IS 'Tanggal dan waktu terakhir data diperbarui.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.updated_by IS 'ID pengguna yang memperbarui data.';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.deleted_at IS 'Tanggal dan waktu data dihapus (soft delete).';
COMMENT ON COLUMN public.penugasan_penyelia_skpd.deleted_by IS 'ID pengguna yang menghapus data.';
CREATE INDEX penugasan_penyelia_skpd_id_unik_penugasan_penyelia_skpd_idx ON public.penugasan_penyelia_skpd USING btree (id_unik_penugasan_penyelia_skpd);
CREATE INDEX penugasan_penyelia_skpd_tahun_idx ON public.penugasan_penyelia_skpd USING btree (tahun);
CREATE INDEX penugasan_penyelia_skpd_id_daerah_idx ON public.penugasan_penyelia_skpd USING btree (id_daerah);
CREATE INDEX penugasan_penyelia_skpd_id_unik_pegawai_idx ON public.penugasan_penyelia_skpd USING btree (id_unik_pegawai);
CREATE INDEX penugasan_penyelia_skpd_id_unik_skpd_idx ON public.penugasan_penyelia_skpd USING btree (id_unik_skpd);
CREATE INDEX penugasan_penyelia_skpd_id_unik_sub_skpd_idx ON public.penugasan_penyelia_skpd USING btree (id_unik_sub_skpd);