deckgl_tracksolid/db/migrations/006_trips_viz_view_v2.sql

42 lines
1.7 KiB
MySQL
Raw Normal View History

-- 006_trips_viz_view_v2.sql
-- Extend trips_viz_v1 with the enrichment columns added in upstream
-- migration 09 (tracksolid.trips: route_geom, start_address, end_address,
-- vehicle_plate, waypoints_count) plus webhook-supplied trip metrics from
-- migration 03 (idle_time_s, driving_time_s, fuel_consumed_l), surfaced via
-- tracksolid.v_trips_enriched (which adds trip_date_eat + daily_seq).
--
-- Columns are appended only — CREATE OR REPLACE VIEW is safe (no column
-- removed, no type changed). Existing consumers see the same first ten
-- columns in the same positions.
CREATE OR REPLACE VIEW public.trips_viz_v1 AS
SELECT
t.id AS trip_id,
t.imei,
d.vehicle_name,
d.vehicle_number,
COALESCE(NULLIF(TRIM(d.cost_centre), ''), 'Unassigned') AS cost_centre,
t.start_time,
t.end_time,
t.distance_km,
t.avg_speed_kmh,
t.max_speed_kmh,
-- ── Enrichment columns (upstream migration 09) ─────────────────────────
COALESCE(t.vehicle_plate, d.vehicle_number) AS vehicle_plate,
t.start_address,
t.end_address,
t.waypoints_count,
-- ── Webhook-supplied trip metrics (upstream migration 03) ──────────────
t.driving_time_s,
t.idle_time_s,
t.fuel_consumed_l,
-- ── Stable per-day trip ordinal (upstream migration 09) ────────────────
t.trip_date_eat,
t.daily_seq
FROM tracksolid.v_trips_enriched t
JOIN tracksolid.devices d ON d.imei = t.imei
WHERE t.start_time IS NOT NULL
AND t.end_time IS NOT NULL;
GRANT SELECT ON public.trips_viz_v1 TO viz_anon;