alter database PA set timezone to 'Australia/Victoria'; create table SETTINGS( ID integer, IMPORT_PATH varchar, constraint PK_SETTINGS_ID primary key(ID) ); create table FILE_TYPE ( ID integer, NAME varchar(32) unique, constraint PK_FILE_TYPE_ID primary key(ID) ); create table ENTRY( ID integer, NAME varchar(128), TYPE_ID integer, constraint PK_ENTRY_ID primary key(ID), constraint FK_FILE_TYPE_TYPE_ID foreign key (TYPE_ID) references FILE_TYPE(ID) ); create table NEW_FILE ( EID integer, SIZE_MB integer, HASH varchar(34), THUMBNAIL varchar, constraint PK_FILE_ID primary key(EID), constraint FK_FILE_ENTRY_ID foreign key (EID) references ENTRY(ID) ); create table DIR ( EID integer, PATH_PREFIX varchar(256), NUM_FILES integer, LAST_IMPORT_DATE float, constraint PK_DIR_EID primary key(EID), constraint FK_DIR_ENTRY_ID foreign key (EID) references ENTRY(ID) ); create table ENTRY_DIR_LINK ( entry_id integer, dir_eid integer, constraint PK_EDL_entry_id_dir_eid primary key (entry_id, dir_eid), constraint FK_EDL_ENTRY_ID foreign key (ENTRY_ID) references ENTRY(ID), constraint FK_EDL_DIR_EID foreign key (DIR_EID) references DIR(EID) ); create table file( id integer, name varchar(128), size_MB integer, type varchar(20), path_prefix varchar(256), hash varchar(34), thumbnail varchar, constraint pk_photos_id primary key(id) ); create table person ( id integer, tag varchar(48), firstname varchar(48), surname varchar(48), constraint pk_person_id primary key(id) ); create table refimg ( id integer, fname varchar(256), constraint pk_refimg_id primary key(id) ); create table file_person_link ( file_id integer, person_id integer, constraint pk_fpl PRIMARY KEY(file_id, person_id), constraint fk_fpl_file_id FOREIGN KEY (file_id) REFERENCES file(id), constraint fk_fpl_person_id FOREIGN KEY (person_id) REFERENCES person(id) ); create table person_refimg_link ( person_id integer, refimg_id integer, constraint pk_prl PRIMARY KEY(person_id, refimg_id), constraint fk_prl_person_id FOREIGN KEY (person_id) REFERENCES person(id), constraint fk_prl_refimg_id FOREIGN KEY (refimg_id) REFERENCES refimg(id), constraint u_prl_refimg_id unique(refimg_id) ); create table job ( id integer, start_time timestamptz, last_update timestamptz, name varchar(64), state varchar(128), num_files integer, current_file_num integer, current_file varchar(256), wait_for integer, pa_job_state varchar(48), constraint pk_job_id primary key(id) ); -- used to pass / keep extra values, e.g. num_files for jobs that have sets of files, or out* for adding output from jobs that you want to pass to next job in the chain create table jobextra ( id integer, job_id integer, name varchar(32), value varchar(1024), constraint pk_jobextra_id primary key(id), constraint fk_jobextra_job_id foreign key(job_id) references job(id) ); create table joblog ( id integer, job_id integer, log_date timestamptz, log varchar, constraint pk_jl_id primary key(id), constraint fk_jl_job_id foreign key(job_id) references job(id) ); create table pa_job_manager ( id integer, state varchar(128), num_active_jobs integer, num_completed_jobs integer, constraint pa_job_manager_id primary key(id) ); create table pa_job_manager_fe_message ( id integer, job_id integer, alert varchar(16), message varchar(1024), constraint pa_job_manager_fe_acks_id primary key(id), constraint fk_pa_job_manager_fe_message_job_id foreign key(job_id) references job(id) ); create sequence file_id_seq; create sequence file_type_id_seq; create sequence jobextra_id_seq; create sequence joblog_id_seq; create sequence job_id_seq; create sequence person_id_seq; create sequence refimg_id_seq; create sequence settings_id_seq; create sequence pa_job_manager_id_seq; create sequence pa_job_manager_fe_message_id_seq; insert into FILE_TYPE values ( (select nextval('file_type_id_seq')), 'Directory' ); insert into FILE_TYPE values ( (select nextval('file_type_id_seq')), 'Image' ); insert into FILE_TYPE values ( (select nextval('file_type_id_seq')), 'Video' ); insert into FILE_TYPE values ( (select nextval('file_type_id_seq')), 'Unknown' ); -- fake data only for making testing easier insert into person values ( (select nextval('person_id_seq')), 'dad', 'Damien', 'De Paoli' ); insert into person values ( (select nextval('person_id_seq')), 'mum', 'Mandy', 'De Paoli' ); insert into person values ( (select nextval('person_id_seq')), 'cam', 'Cameron', 'De Paoli' ); insert into person values ( (select nextval('person_id_seq')), 'mich', 'Michelle', 'De Paoli' ); insert into refimg values ( (select nextval('refimg_id_seq')), 'dad.jpg'); insert into refimg values ( (select nextval('refimg_id_seq')), 'mum.jpg'); insert into refimg values ( (select nextval('refimg_id_seq')), 'cam.jpg'); insert into refimg values ( (select nextval('refimg_id_seq')), 'mich.jpg'); insert into person_refimg_link values ( 1, 1 ); insert into person_refimg_link values ( 2, 2 ); insert into person_refimg_link values ( 3, 3 ); insert into person_refimg_link values ( 4, 4 ); insert into settings values ( (select nextval('settings_id_seq')), '/home/ddp/src/photoassistant/images_to_process/#c:/Users/cam/Desktop/code/python/photoassistant/photos/#/home/ddp/src/photoassistant/new_img_dir/' );