TimeTrex/classes/modules/install/sql/postgresql/1031A.sql

176 lines
9.1 KiB
SQL

CREATE TABLE wage_group (
id serial NOT NULL,
company_id integer NOT NULL,
name character varying,
created_date integer,
created_by integer,
updated_date integer,
updated_by integer,
deleted_date integer,
deleted_by integer,
deleted integer DEFAULT 0 NOT NULL
);
CREATE INDEX wage_group_id ON wage_group USING btree (id);
ALTER TABLE user_wage ADD COLUMN wage_group_id integer DEFAULT 0 NOT NULL;
ALTER TABLE user_wage ADD COLUMN hourly_rate numeric(11,4) NULL;
ALTER TABLE user_wage ALTER COLUMN wage type numeric(11,4);
ALTER TABLE over_time_policy ADD COLUMN wage_group_id integer DEFAULT 0 NOT NULL;
ALTER TABLE absence_policy ADD COLUMN wage_group_id integer DEFAULT 0 NOT NULL;
ALTER TABLE absence_policy ADD COLUMN rate numeric(9,4) NULL;
ALTER TABLE absence_policy ADD COLUMN accrual_rate numeric(9,4) NULL;
UPDATE absence_policy set rate = 1.0;
UPDATE absence_policy set accrual_rate = 1.0;
ALTER TABLE premium_policy ADD COLUMN wage_group_id integer DEFAULT 0 NOT NULL;
ALTER TABLE pay_period_schedule ADD COLUMN shift_assigned_day_id integer NULL;
ALTER TABLE pay_period_schedule ADD COLUMN timesheet_verify_before_end_date integer NULL;
ALTER TABLE pay_period_schedule ADD COLUMN timesheet_verify_before_transaction_date integer NULL;
ALTER TABLE pay_period_schedule ADD COLUMN timesheet_verify_notice_before_transaction_date integer NULL;
ALTER TABLE pay_period_schedule ADD COLUMN timesheet_verify_notice_email integer NULL;
ALTER TABLE pay_period_schedule ADD COLUMN annual_pay_periods integer NULL;
ALTER TABLE meal_policy ADD COLUMN auto_detect_type_id integer DEFAULT 10 NOT NULL;
ALTER TABLE meal_policy ADD COLUMN minimum_punch_time integer;
ALTER TABLE meal_policy ADD COLUMN maximum_punch_time integer;
CREATE TABLE company_generic_map (
id serial NOT NULL,
company_id integer NOT NULL,
object_type_id integer NOT NULL,
object_id integer NULL,
map_id integer NULL
);
CREATE INDEX company_generic_map_id ON company_generic_map USING btree (id);
CREATE INDEX company_generic_map_company_id_object_type_id_object_id ON company_generic_map USING btree (company_id,object_type_id,object_id);
insert into company_generic_map (company_id,object_type_id,object_id,map_id) (select a.company_id as company_id,110 as object_type_id,a.id as object_id,b.over_time_policy_id as map_id from policy_group as a, policy_group_over_time_policy as b WHERE a.id = b.policy_group_id);
insert into company_generic_map (company_id,object_type_id,object_id,map_id) (select a.company_id as company_id,120 as object_type_id,a.id as object_id,b.premium_policy_id as map_id from policy_group as a, policy_group_premium_policy as b WHERE a.id = b.policy_group_id);
insert into company_generic_map (company_id,object_type_id,object_id,map_id) (select a.company_id as company_id,130 as object_type_id,a.id as object_id,b.round_interval_policy_id as map_id from policy_group as a, policy_group_round_interval_policy as b WHERE a.id = b.policy_group_id);
insert into company_generic_map (company_id,object_type_id,object_id,map_id) (select a.company_id as company_id,140 as object_type_id,a.id as object_id,b.accrual_policy_id as map_id from policy_group as a, policy_group_accrual_policy as b WHERE a.id = b.policy_group_id);
insert into company_generic_map (company_id,object_type_id,object_id,map_id) (select a.company_id as company_id,150 as object_type_id,a.id as object_id,a.meal_policy_id as map_id from policy_group as a WHERE a.meal_policy_id is not NULL);
insert into company_generic_map (company_id,object_type_id,object_id,map_id) (select a.company_id as company_id,180 as object_type_id,a.id as object_id,a.holiday_policy_id as map_id from policy_group as a WHERE a.holiday_policy_id is not NULL);
ALTER TABLE policy_group DROP column meal_policy_id;
ALTER TABLE policy_group DROP column holiday_policy_id;
drop table policy_group_accrual_policy;
drop table policy_group_round_interval_policy;
drop table policy_group_premium_policy;
drop table policy_group_over_time_policy;
CREATE TABLE break_policy (
id serial NOT NULL,
company_id integer NOT NULL,
name character varying NOT NULL,
type_id integer NOT NULL,
trigger_time integer,
amount integer NOT NULL,
auto_detect_type_id integer NOT NULL,
start_window integer,
window_length integer,
minimum_punch_time integer,
maximum_punch_time integer,
include_break_punch_time smallint,
created_date integer,
created_by integer,
updated_date integer,
updated_by integer,
deleted_date integer,
deleted_by integer,
deleted smallint DEFAULT 0 NOT NULL
);
ALTER TABLE user_date_total ADD COLUMN break_policy_id integer DEFAULT 0;
ALTER TABLE premium_policy ADD COLUMN include_break_policy smallint DEFAULT 0;
update exception_policy set type_id = 'S1' where type_id = 'A';
update exception_policy set type_id = 'S2' where type_id = 'B';
update exception_policy set type_id = 'S3' where type_id = 'C';
update exception_policy set type_id = 'S4' where type_id = 'D';
update exception_policy set type_id = 'S5' where type_id = 'E';
update exception_policy set type_id = 'S6' where type_id = 'F';
update exception_policy set type_id = 'S7' where type_id = 'G';
update exception_policy set type_id = 'S8' where type_id = 'H';
update exception_policy set type_id = 'M1' where type_id = 'K';
update exception_policy set type_id = 'M2' where type_id = 'L';
update exception_policy set type_id = 'L1' where type_id = 'M';
update exception_policy set type_id = 'L2' where type_id = 'N';
update exception_policy set type_id = 'L3' where type_id = 'O';
update exception_policy set type_id = 'M3' where type_id = 'P';
update exception_policy set type_id = 'J1' where type_id = 'T';
update exception_policy set type_id = 'J2' where type_id = 'U';
update exception_policy set type_id = 'J3' where type_id = 'V';
update exception_policy set type_id = 'J4' where type_id = 'W';
update holiday_policy set type_id = 30 where type_id = 10;
ALTER TABLE holiday_policy ADD COLUMN worked_scheduled_days smallint DEFAULT 0;
ALTER TABLE holiday_policy ADD COLUMN minimum_worked_after_period_days integer DEFAULT 0;
ALTER TABLE holiday_policy ADD COLUMN minimum_worked_after_days integer DEFAULT 0;
ALTER TABLE holiday_policy ADD COLUMN worked_after_scheduled_days smallint DEFAULT 0;
ALTER TABLE holiday_policy ADD COLUMN paid_absence_as_worked smallint DEFAULT 0;
CREATE TABLE hierarchy_level (
id serial NOT NULL,
hierarchy_control_id integer NOT NULL,
level integer NOT NULL,
user_id integer NOT NULL,
created_date integer,
created_by integer,
updated_date integer,
updated_by integer,
deleted_date integer,
deleted_by integer,
deleted integer DEFAULT 0 NOT NULL
);
CREATE INDEX hierarchy_level_hierarchy_control_id_user_id ON hierarchy_level USING btree (hierarchy_control_id,user_id);
CREATE TABLE hierarchy_user (
id serial NOT NULL,
hierarchy_control_id integer NOT NULL,
user_id integer NOT NULL
);
CREATE INDEX hierarchy_user_hierarchy_control_id_user_id ON hierarchy_user USING btree (hierarchy_control_id,user_id);
ALTER TABLE request ADD COLUMN authorization_level smallint DEFAULT 99;
ALTER TABLE pay_period_time_sheet_verify ADD COLUMN authorization_level smallint DEFAULT 99;
create index recurring_schedule_template_schedule_template_control_id ON recurring_schedule_template(recurring_schedule_template_control_id);
ALTER TABLE pay_stub_entry ALTER COLUMN rate type numeric(11,4);
ALTER TABLE pay_stub_entry ALTER COLUMN units type numeric(11,4);
ALTER TABLE pay_stub_entry ALTER COLUMN ytd_units type numeric(11,4);
ALTER TABLE pay_stub_amendment ALTER COLUMN rate type numeric(11,4);
ALTER TABLE pay_stub_amendment ALTER COLUMN units type numeric(11,4);
ALTER TABLE recurring_ps_amendment ALTER COLUMN rate type numeric(11,4);
ALTER TABLE recurring_ps_amendment ALTER COLUMN units type numeric(11,4);
ALTER TABLE recurring_holiday RENAME COLUMN easter TO special_day;
UPDATE branch set province = 'NL' where province = 'NF';
UPDATE company set province = 'NL' where province = 'NF';
UPDATE users set province = 'NL' where province = 'NF';
UPDATE user_default set province = 'NL' where province = 'NF';
UPDATE branch set province = 'YU' where province = 'YT';
UPDATE company set province = 'YU' where province = 'YT';
UPDATE users set province = 'YU' where province = 'YT';
UPDATE user_default set province = 'YU' where province = 'YT';
ALTER TABLE company_deduction ADD COLUMN start_date timestamp without time zone;
ALTER TABLE company_deduction ADD COLUMN end_date timestamp without time zone;
ALTER TABLE company_deduction ADD COLUMN minimum_length_of_service numeric(11,4);
ALTER TABLE company_deduction ADD COLUMN minimum_length_of_service_unit_id smallint;
ALTER TABLE company_deduction ADD COLUMN minimum_length_of_service_days numeric(11,4);
ALTER TABLE company_deduction ADD COLUMN maximum_length_of_service numeric(11,4);
ALTER TABLE company_deduction ADD COLUMN maximum_length_of_service_unit_id smallint;
ALTER TABLE company_deduction ADD COLUMN maximum_length_of_service_days numeric(11,4);
ALTER TABLE company_deduction ADD COLUMN include_account_amount_type_id smallint DEFAULT 10;
ALTER TABLE company_deduction ADD COLUMN exclude_account_amount_type_id smallint DEFAULT 10;
ALTER TABLE station ADD COLUMN job_id integer DEFAULT 0;
ALTER TABLE station ADD COLUMN job_item_id integer DEFAULT 0;