\connect sova_backend_test DROP SCHEMA public CASCADE; CREATE SCHEMA public; GRANT ALL ON SCHEMA public TO sova_test; CREATE TABLE users ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, uid INTEGER NOT NULL UNIQUE, email VARCHAR(180), roles JSONB NOT NULL DEFAULT '[]', region_id INTEGER NOT NULL DEFAULT 91, password VARCHAR(255) NOT NULL, birth_date DATE, logged_in TIMESTAMP ); CREATE TABLE departments ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, did BIGINT NOT NULL UNIQUE, name VARCHAR(255) NOT NULL, online_mode BOOLEAN NOT NULL DEFAULT true, alias VARCHAR(255) NOT NULL, active BOOLEAN NOT NULL DEFAULT true, group_name VARCHAR(255) ); CREATE TABLE filial ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, fid INTEGER NOT NULL UNIQUE, name VARCHAR(255) NOT NULL, address VARCHAR(255), region_id INTEGER, site_id INTEGER, active BOOLEAN NOT NULL DEFAULT true, company VARCHAR(255), short_name VARCHAR(255), phone VARCHAR(255), policy TEXT, picture VARCHAR(255), email VARCHAR(255), origin VARCHAR(255) ); CREATE TABLE specialist ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255) NOT NULL, preview_picture VARCHAR(255), active BOOLEAN NOT NULL DEFAULT true, display_schedule BOOLEAN NOT NULL DEFAULT true, dcodes VARCHAR(255), region_id INTEGER, alias VARCHAR(255) NOT NULL, post VARCHAR(255), experience VARCHAR(255), s_type INTEGER, update_at TIMESTAMP NOT NULL DEFAULT now(), anons TEXT, content TEXT, tags JSONB, highlighted_tags JSONB, video VARCHAR(255), video_vertical VARCHAR(255), schedule_text VARCHAR(255), category VARCHAR(255), patient_age INTEGER, kodoper JSONB, only_online_mode BOOLEAN, prodoctor BOOLEAN, prodoctor_text VARCHAR(255), prodoctor_link VARCHAR(255), degree VARCHAR(255), kiosk BOOLEAN NOT NULL DEFAULT false, filials JSONB, accepts_dms BOOLEAN, specialities JSONB ); CREATE TABLE location ( id BIGINT GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, dcode BIGINT, department BIGINT NOT NULL, filial INTEGER NOT NULL, online_mode BOOLEAN NOT NULL DEFAULT true, active BOOLEAN NOT NULL DEFAULT true, nearest_date DATE, specialist_id INTEGER REFERENCES specialist(id) ON DELETE CASCADE ); CREATE TABLE review ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, specialist_id INTEGER REFERENCES specialist(id) ON DELETE CASCADE, active BOOLEAN NOT NULL DEFAULT true, date_create DATE NOT NULL DEFAULT CURRENT_DATE, message TEXT NOT NULL, author VARCHAR(255) NOT NULL, rating DOUBLE PRECISION NOT NULL DEFAULT 5, source VARCHAR(255), external_id INTEGER ); CREATE TABLE specialist_docs ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, specialist_id INTEGER REFERENCES specialist(id) ON DELETE CASCADE, name VARCHAR(255) NOT NULL, description VARCHAR(255), picture VARCHAR(255), active BOOLEAN NOT NULL DEFAULT true, type VARCHAR(255) NOT NULL ); CREATE TABLE specialist_dcode_description ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, dcode BIGINT NOT NULL, department BIGINT, specialist_id INTEGER NOT NULL REFERENCES specialist(id) ON DELETE CASCADE, content TEXT NOT NULL, create_at TIMESTAMP NOT NULL DEFAULT now(), update_at TIMESTAMP NOT NULL DEFAULT now() ); CREATE TABLE stock ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255) NOT NULL, content TEXT NOT NULL, picture VARCHAR(255), anons TEXT, start_date TIMESTAMP NOT NULL DEFAULT now(), end_date TIMESTAMP NOT NULL DEFAULT now() + interval '30 days' ); CREATE TABLE stock_specialist ( stock_id INTEGER NOT NULL REFERENCES stock(id) ON DELETE CASCADE, specialist_id INTEGER NOT NULL REFERENCES specialist(id) ON DELETE CASCADE, PRIMARY KEY (stock_id, specialist_id) ); CREATE TABLE price_department ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255) NOT NULL, group_id INTEGER NOT NULL, doct_count INTEGER DEFAULT 0, view_in_web BOOLEAN DEFAULT true ); CREATE TABLE price_list ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, kodoper INTEGER, schname VARCHAR(255), specname VARCHAR(255), speccode INTEGER, price_info JSONB, discprice NUMERIC(10,2), structname VARCHAR(255), fname VARCHAR(255), filial INTEGER, comment TEXT, media_id INTEGER, date_update TIMESTAMP DEFAULT now(), group_id INTEGER, discpercent INTEGER ); CREATE TABLE schedule ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, dcode BIGINT, department BIGINT, filial INTEGER, schedident BIGINT, workdate DATE, rnum VARCHAR(255), rfloor VARCHAR(255), rbuilding VARCHAR(255), time JSONB, is_free BOOLEAN DEFAULT true, online_mode BOOLEAN DEFAULT false, query_string TEXT, created_at TIMESTAMP DEFAULT now(), interval_is_free BOOLEAN DEFAULT true, price_info NUMERIC(10,2) ); CREATE TABLE record ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, specialist_id INTEGER NOT NULL, phone VARCHAR(255) NOT NULL, create_at TIMESTAMP NOT NULL DEFAULT now(), hash VARCHAR(255) NOT NULL, reserve JSONB NOT NULL DEFAULT '{}' ); CREATE TABLE alert_sms ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, record_id INTEGER UNIQUE REFERENCES record(id) ON DELETE CASCADE, date_create TIMESTAMP NOT NULL DEFAULT now(), response TEXT NOT NULL ); CREATE TABLE widget_form ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255) NOT NULL ); CREATE TABLE widget_form_input ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, text VARCHAR(255) NOT NULL, type VARCHAR(255) NOT NULL, bitrix24_id VARCHAR(255) NOT NULL, widget_form_id INTEGER NOT NULL REFERENCES widget_form(id) ON DELETE CASCADE, sort INTEGER NOT NULL DEFAULT 100 ); CREATE TABLE article ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name TEXT, preview_picture TEXT, active BOOLEAN DEFAULT true, doctors JSONB, services JSONB, region_id INTEGER, alias TEXT, anons TEXT, content TEXT, update_at TIMESTAMP DEFAULT now() ); CREATE TABLE disease ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255), preview_picture VARCHAR(255), active BOOLEAN DEFAULT true, region_id INTEGER, alias VARCHAR(255), anons TEXT, update_at TIMESTAMP DEFAULT now(), hide_picture BOOLEAN, read_time TEXT, diseases_name TEXT, tags_important JSONB, tags JSONB, diseases_other_name TEXT, symptom TEXT, staff TEXT, link_services JSONB, staff_list JSONB, staff_post JSONB, staff_post_exclude JSONB, link_faq JSONB, bibliography TEXT, staff_check JSONB, content TEXT ); CREATE TABLE medical_center ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255), active BOOLEAN DEFAULT true, region_id INTEGER, alias VARCHAR(255), anons TEXT, content TEXT, update_at TIMESTAMP DEFAULT now(), kod_uslug JSONB, doctors JSONB, services JSONB, articles JSONB, txt_up JSONB, main_link_staff TEXT, contraindications JSONB, hide_picture INTEGER, indications JSONB, link_sale JSONB, plus_list JSONB, plus_text TEXT, plus_title TEXT, process_text TEXT, process_title TEXT, services_list JSONB, services_photos JSONB, services_title TEXT, sort_staff JSONB, training_text TEXT, training_text_title TEXT, why_text TEXT, why_title TEXT ); CREATE TABLE news ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255), active BOOLEAN DEFAULT true, region_id INTEGER, alias VARCHAR(255), anons TEXT, content TEXT, update_at TIMESTAMP DEFAULT now(), link_el_price TEXT, short_name TEXT, timer TEXT, timer_bg TEXT, form_order JSONB, link_services JSONB, link_staff JSONB, photos JSONB ); CREATE TABLE promo ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255), active BOOLEAN DEFAULT true, region_id INTEGER, alias VARCHAR(255), anons TEXT, content TEXT, update_at TIMESTAMP DEFAULT now(), clinics JSONB, timer TEXT, timer_bg TEXT, short_name TEXT, link_services JSONB, link_staff JSONB, period VARCHAR(255), photos JSONB ); CREATE TABLE site_services ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, name VARCHAR(255), active BOOLEAN DEFAULT true, region_id INTEGER, alias VARCHAR(255), anons TEXT, content TEXT, update_at TIMESTAMP DEFAULT now(), link_videoreviews JSONB, preview_img TEXT, faq JSONB, part_price TEXT, pokazaniya TEXT, preparation TEXT, protivopokazaniya TEXT, hide_sign_btn JSONB, quiz JSONB, tags JSONB, tags_important JSONB, banner_img TEXT, banner_img_m TEXT, banner_img_url TEXT, clinics JSONB, download_file TEXT, full_width_banner TEXT, staff_up JSONB, advantages JSONB, hide_picture INTEGER, kod_uslug TEXT, link_price TEXT, photos_title TEXT, sale_id JSONB, sort_staff JSONB, contraindications_list TEXT, custom_block_text TEXT, custom_block_text2 TEXT, custom_block_title TEXT, custom_block_title2 TEXT, indications_list TEXT, link_articles_services JSONB, plus_list TEXT, plus_text TEXT, plus_title TEXT, prepare_title TEXT, process_text TEXT, process_title TEXT, services_list TEXT, services_photos JSONB, services_title TEXT, text_up TEXT, training_text TEXT, why_text TEXT, why_title TEXT, link_faq JSONB, link_services JSONB, link_staff JSONB, photos JSONB ); CREATE TABLE web_get_docinfo ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, source_table VARCHAR(255), doc_name VARCHAR(255), doc_post VARCHAR(255), filial INTEGER, viewinweb BOOLEAN, depnum INTEGER, first_schid INTEGER, second_schid INTEGER, accepts_dms BOOLEAN, anons TEXT, content TEXT, updated_at TIMESTAMP DEFAULT now() ); CREATE TABLE idoctor ( id INTEGER GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY, dcode INTEGER, name VARCHAR(255), department INTEGER, filial INTEGER, nearest_date DATE, online_mode BOOLEAN DEFAULT true, updated TIMESTAMP DEFAULT now() );