Czyszczenie bazy danych przed uruchomieniem

Po okresie testowania klient życzy sobie aby wyczyścić bazę. Można to zrobić poprzez wywołanie odpowiednich komend w bazie danych.

-- wyczyszczenie tabel z rekordami dziennikow
delete from regofpapers ;
delete from regofvatnotes;

-- wyczyszczenie tabel dokumentow
delete from documents;
delete from documents_history;
delete from attachments;


-- wyzerowanie liczników
update counters set cntval = 0;
update documents set doc_id = 0;
update briefcases set countr = 0;
update doss_extract_list set countr = 0;

-- wyczyszczenie zdarzen
delete from rcp_cards;
delete from events;
delete from process_comments;
delete from process_participants;
delete from processes;
delete from processes_link_users;

-- czyczczenie etapów, procedur
delete from stages;
delete from procedures;

-- Czyszczenie logów
delete from log;
delete from log_trace;
delete from login_history;

-- Czyszczenie wszystkich Komentarzy
delete from readed_comments;
delete from comments;

-- Czyszczenie powiadomień
delete from jabber_messages_archive;
delete from jabber_messages;

-- Czyszczenie tabel powiązanych z fakturą
delete from fk_vat_decomposition_list;
delete from vatnote;
delete from vatnote_costs;


-- czyszczenie usuniętych wpisów
DELETE from fk_elements WHERE doc_id IN (SELECT doc_id FROM documents where adduid IN (SELECT usr_id FROM users where is_del is true));

delete from documents where adduid IN (SELECT usr_id FROM users where is_del is true);

delete from rcp_cards WHERE emp_id IN(SELECT usr_id FROM users where is_del is true);

delete from readed_comments where usr_id IN (SELECT usr_id FROM users where is_del is true);

delete from contacts_caretakers where usr_id IN (SELECT usr_id FROM users where is_del is true);

delete from vindication.vind_proc where vindyc IN (SELECT usr_id FROM users where is_del is true);

DELETE from fk_elements WHERE adduid IN (SELECT usr_id FROM users where is_del is true);

delete from users where is_del is true;

delete from rcp_cards WHERE prc_id IN(select prc_id from processes where is_del is true);

delete from fk_elements WHERE prc_id IN(select prc_id from processes where is_del is true);

delete from process_participants WHERE prc_id IN(select prc_id from processes where is_del is true);

delete from processes where is_del is true;

delete FROM organization_units WHERE is_del IS TRUE;

delete from fk_elements WHERE doc_id IN(SELECT doc_id FROM documents where is_del is true);

delete from documents where is_del is true;




Po testach procedur również można wyczyścić instancje procedur :

DELETE FROM procedures p WHERE NOT EXISTS (SELECT d.procid FROM documents d WHERE p.procid = d.procid AND d.procid IS NOT NULL) AND
NOT EXISTS (SELECT d.procid FROM processes d WHERE p.procid = d.procid AND d.procid IS NOT NULL) AND
NOT EXISTS (SELECT d.procid FROM rcp_cards d WHERE p.procid = d.procid AND d.procid IS NOT NULL) 

Policzyć można je za pomocą:

SELECT count(procid) FROM procedures p WHERE NOT EXISTS (SELECT d.procid FROM documents d WHERE p.procid = d.procid AND d.procid IS NOT NULL) AND
NOT EXISTS (SELECT d.procid FROM processes d WHERE p.procid = d.procid AND d.procid IS NOT NULL) AND
NOT EXISTS (SELECT d.procid FROM rcp_cards d WHERE p.procid = d.procid AND d.procid IS NOT NULL)