QUERY PLAN
Limit (cost=650.07..650.12 rows=20 width=207)
-> Sort (cost=650.07..650.25 rows=72 width=207)
Sort Key: ps.end_at DESC, ps.updated_at DESC
-> Hash Left Join (cost=282.81..648.15 rows=72 width=207)
Hash Cond: (ps.client_id = client.id)
-> Hash Left Join (cost=138.76..503.73 rows=72 width=150)
Hash Cond: (ps.service_id = s.id)
-> Nested Loop Left Join (cost=121.58..486.37 rows=72 width=118)
-> Hash Left Join (cost=121.44..474.38 rows=72 width=109)
Hash Cond: (ps.created_by = u.id)
-> Nested Loop Left Join (cost=112.27..465.01 rows=72 width=104)
-> Hash Right Join (cost=111.99..438.24 rows=72 width=82)
Hash Cond: (c.id = ps.case_id)
Filter: ((c.deduct_points_from = ANY ('{1001,5049,5301,5022,5209,5026,5293,5309,5356,5329,5299,5303,5302,5332,5047,1026,5096,5070,5448,5420,1029,5037,5087,1008,5048,5043,5045,5230,5031,5088,5208,1003,5294,5357,5044,1030,5076,5300,5027,5089,5311,5066,5069,5364,1009,5295,1013,5128,5203,1025,5032,5075,1004,5072,5033,5359,5409,5412,5229,1005,5304,5449,5358,1006,5093}'::integer[])) OR (c.deduct_points_from IS NULL))
-> Seq Scan on tbl_cases c (cost=0.00..257.31 rows=8231 width=28)
-> Hash (cost=111.00..111.00 rows=79 width=58)
-> Seq Scan on tbl_pre_sales ps (cost=0.00..111.00 rows=79 width=58)
Filter: ((NOT is_draft) AND (start_at >= '2025-01-01 00:00:00+08'::timestamp with time zone) AND (start_at <= '2025-12-31 23:59:59+08'::timestamp with time zone) AND (created_by = ANY ('{1017,5085,1001,5248,1015,1022,5296,1023}'::integer[])))
-> Index Scan using tbl_projects_pkey on tbl_projects p (cost=0.28..0.37 rows=1 width=26)
Index Cond: (c.project_id = id)
-> Hash (cost=7.41..7.41 rows=141 width=13)
-> Seq Scan on tbl_users u (cost=0.00..7.41 rows=141 width=13)
-> Index Scan using tbl_users_pkey on tbl_users sales (cost=0.14..0.17 rows=1 width=13)
Index Cond: (c.deduct_points_from = id)
-> Hash (cost=14.30..14.30 rows=230 width=36)
-> Seq Scan on tbl_services s (cost=0.00..14.30 rows=230 width=36)
-> Hash (cost=119.58..119.58 rows=1958 width=45)
-> Seq Scan on tbl_clients client (cost=0.00..119.58 rows=1958 width=45)