开发机迁移
This commit is contained in:
@@ -439,8 +439,10 @@ SELECT table_fee_log_id,
|
||||
WHERE (site_id = (current_setting('app.current_site_id'::text))::bigint);
|
||||
;
|
||||
|
||||
-- CHANGE 2026-04-08 | DISTINCT ON 只取每对 (assistant, member) 最新快照
|
||||
CREATE OR REPLACE VIEW app.v_dws_assistant_customer_stats AS
|
||||
SELECT id,
|
||||
SELECT DISTINCT ON (assistant_id, member_id)
|
||||
id,
|
||||
site_id,
|
||||
tenant_id,
|
||||
assistant_id,
|
||||
@@ -478,7 +480,8 @@ SELECT id,
|
||||
created_at,
|
||||
updated_at
|
||||
FROM dws.dws_assistant_customer_stats
|
||||
WHERE (site_id = (current_setting('app.current_site_id'::text))::bigint);
|
||||
WHERE (site_id = (current_setting('app.current_site_id'::text))::bigint)
|
||||
ORDER BY assistant_id, member_id, stat_date DESC;
|
||||
;
|
||||
|
||||
CREATE OR REPLACE VIEW app.v_dws_assistant_daily_detail AS
|
||||
@@ -976,8 +979,10 @@ SELECT relation_id,
|
||||
WHERE (site_id = (current_setting('app.current_site_id'::text))::bigint);
|
||||
;
|
||||
|
||||
-- CHANGE 2026-04-08 | DISTINCT ON 只取每个会员最新快照,避免多 stat_date 行膨胀
|
||||
CREATE OR REPLACE VIEW app.v_dws_member_consumption_summary AS
|
||||
SELECT id,
|
||||
SELECT DISTINCT ON (member_id)
|
||||
id,
|
||||
site_id,
|
||||
tenant_id,
|
||||
member_id,
|
||||
@@ -1024,7 +1029,8 @@ SELECT id,
|
||||
recharge_amount_90d,
|
||||
avg_ticket_amount
|
||||
FROM dws.dws_member_consumption_summary
|
||||
WHERE (site_id = (current_setting('app.current_site_id'::text))::bigint);
|
||||
WHERE (site_id = (current_setting('app.current_site_id'::text))::bigint)
|
||||
ORDER BY member_id, stat_date DESC;
|
||||
;
|
||||
|
||||
CREATE OR REPLACE VIEW app.v_dws_member_newconv_index AS
|
||||
@@ -1042,6 +1048,7 @@ SELECT newconv_id,
|
||||
t_r,
|
||||
t_a,
|
||||
visits_14d,
|
||||
visits_30d,
|
||||
visits_60d,
|
||||
visits_total,
|
||||
spend_30d,
|
||||
@@ -1167,6 +1174,7 @@ SELECT winback_id,
|
||||
t_r,
|
||||
t_a,
|
||||
visits_14d,
|
||||
visits_30d,
|
||||
visits_60d,
|
||||
visits_total,
|
||||
spend_30d,
|
||||
|
||||
@@ -789,6 +789,7 @@ CREATE TABLE dws.dws_member_newconv_index (
|
||||
t_r numeric(6,2),
|
||||
t_a numeric(6,2),
|
||||
visits_14d integer DEFAULT 0 NOT NULL,
|
||||
visits_30d integer DEFAULT 0 NOT NULL,
|
||||
visits_60d integer DEFAULT 0 NOT NULL,
|
||||
visits_total integer DEFAULT 0 NOT NULL,
|
||||
spend_30d numeric(14,2) DEFAULT 0 NOT NULL,
|
||||
@@ -907,6 +908,7 @@ CREATE TABLE dws.dws_member_winback_index (
|
||||
t_r numeric(6,2),
|
||||
t_a numeric(6,2),
|
||||
visits_14d integer DEFAULT 0 NOT NULL,
|
||||
visits_30d integer DEFAULT 0 NOT NULL,
|
||||
visits_60d integer DEFAULT 0 NOT NULL,
|
||||
visits_total integer DEFAULT 0 NOT NULL,
|
||||
spend_30d numeric(14,2) DEFAULT 0 NOT NULL,
|
||||
@@ -1297,6 +1299,7 @@ SELECT dws_member_winback_index.site_id,
|
||||
dws_member_winback_index.t_r,
|
||||
dws_member_winback_index.t_a,
|
||||
dws_member_winback_index.visits_14d,
|
||||
dws_member_winback_index.visits_30d,
|
||||
dws_member_winback_index.visits_60d,
|
||||
dws_member_winback_index.visits_total,
|
||||
dws_member_winback_index.spend_30d,
|
||||
@@ -1332,6 +1335,7 @@ UNION ALL
|
||||
dws_member_newconv_index.t_r,
|
||||
dws_member_newconv_index.t_a,
|
||||
dws_member_newconv_index.visits_14d,
|
||||
dws_member_newconv_index.visits_30d,
|
||||
dws_member_newconv_index.visits_60d,
|
||||
dws_member_newconv_index.visits_total,
|
||||
dws_member_newconv_index.spend_30d,
|
||||
|
||||
@@ -16,6 +16,7 @@ CREATE SEQUENCE IF NOT EXISTS biz.cfg_task_generator_params_id_seq AS bigint;
|
||||
CREATE SEQUENCE IF NOT EXISTS biz.coach_task_history_id_seq AS bigint;
|
||||
CREATE SEQUENCE IF NOT EXISTS biz.coach_task_transfer_log_id_seq AS bigint;
|
||||
CREATE SEQUENCE IF NOT EXISTS biz.coach_tasks_id_seq AS bigint;
|
||||
CREATE SEQUENCE IF NOT EXISTS biz.recall_events_id_seq AS bigint;
|
||||
CREATE SEQUENCE IF NOT EXISTS biz.connectors_id_seq AS integer;
|
||||
CREATE SEQUENCE IF NOT EXISTS biz.dws_assistant_task_monthly_id_seq AS bigint;
|
||||
CREATE SEQUENCE IF NOT EXISTS biz.excel_upload_log_id_seq AS bigint;
|
||||
@@ -153,6 +154,7 @@ CREATE TABLE biz.coach_tasks (
|
||||
abandon_reason text,
|
||||
completed_at timestamp with time zone,
|
||||
completed_task_type character varying(50),
|
||||
completion_type character varying(10),
|
||||
parent_task_id bigint,
|
||||
created_at timestamp with time zone DEFAULT now(),
|
||||
updated_at timestamp with time zone DEFAULT now(),
|
||||
@@ -161,6 +163,17 @@ CREATE TABLE biz.coach_tasks (
|
||||
transferred_at timestamp with time zone
|
||||
);
|
||||
|
||||
CREATE TABLE biz.recall_events (
|
||||
id bigint DEFAULT nextval('biz.recall_events_id_seq'::regclass) NOT NULL,
|
||||
site_id bigint NOT NULL,
|
||||
assistant_id bigint NOT NULL,
|
||||
member_id bigint NOT NULL,
|
||||
pay_time timestamp with time zone NOT NULL,
|
||||
task_id bigint,
|
||||
task_type character varying(50),
|
||||
created_at timestamp with time zone DEFAULT now()
|
||||
);
|
||||
|
||||
CREATE TABLE biz.connectors (
|
||||
id integer DEFAULT nextval('biz.connectors_id_seq'::regclass) NOT NULL,
|
||||
connector_key character varying(50) NOT NULL,
|
||||
@@ -341,6 +354,8 @@ ALTER TABLE biz.dws_assistant_task_monthly ADD CONSTRAINT dws_assistant_task_mon
|
||||
ALTER TABLE biz.excel_upload_log ADD CONSTRAINT excel_upload_log_pkey PRIMARY KEY (id);
|
||||
ALTER TABLE biz.notes ADD CONSTRAINT notes_task_id_fkey FOREIGN KEY (task_id) REFERENCES biz.coach_tasks(id);
|
||||
ALTER TABLE biz.notes ADD CONSTRAINT notes_pkey PRIMARY KEY (id);
|
||||
ALTER TABLE biz.recall_events ADD CONSTRAINT recall_events_pkey PRIMARY KEY (id);
|
||||
ALTER TABLE biz.recall_events ADD CONSTRAINT recall_events_task_id_fkey FOREIGN KEY (task_id) REFERENCES biz.coach_tasks(id);
|
||||
ALTER TABLE biz.salary_adjustments ADD CONSTRAINT salary_adjustments_upload_batch_id_fkey FOREIGN KEY (upload_batch_id) REFERENCES biz.excel_upload_log(id);
|
||||
ALTER TABLE biz.salary_adjustments ADD CONSTRAINT salary_adjustments_pkey PRIMARY KEY (id);
|
||||
ALTER TABLE biz.site_code_history ADD CONSTRAINT site_code_history_pkey PRIMARY KEY (id);
|
||||
@@ -386,5 +401,7 @@ CREATE INDEX idx_task_monthly_site_month ON biz.dws_assistant_task_monthly USING
|
||||
CREATE INDEX idx_excel_log_site ON biz.excel_upload_log USING btree (site_id, created_at DESC);
|
||||
CREATE INDEX idx_notes_target ON biz.notes USING btree (site_id, target_type, target_id);
|
||||
CREATE INDEX idx_salary_adj_assistant_month ON biz.salary_adjustments USING btree (assistant_id, salary_month);
|
||||
CREATE UNIQUE INDEX idx_recall_events_site_assistant_member_day ON biz.recall_events USING btree (site_id, assistant_id, member_id, (date_trunc('day', pay_time AT TIME ZONE 'Asia/Shanghai')));
|
||||
CREATE INDEX idx_recall_events_assistant_pay ON biz.recall_events USING btree (site_id, assistant_id, pay_time);
|
||||
CREATE INDEX idx_salary_adj_site_month ON biz.salary_adjustments USING btree (site_id, salary_month);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user