2026-03-26 08:37:53 +00:00
|
|
|
-- Mart: Canonical school dimension — one row per active URN
|
|
|
|
|
|
|
|
|
|
with schools as (
|
|
|
|
|
select * from {{ ref('stg_gias_establishments') }}
|
|
|
|
|
)
|
|
|
|
|
|
2026-03-26 20:43:24 +00:00
|
|
|
{% set ofsted_relation = adapter.get_relation(
|
|
|
|
|
database=target.database,
|
2026-04-13 14:51:14 +01:00
|
|
|
schema='intermediate',
|
2026-03-26 20:43:24 +00:00
|
|
|
identifier='int_ofsted_latest'
|
|
|
|
|
) %}
|
|
|
|
|
|
2026-03-26 08:37:53 +00:00
|
|
|
select
|
|
|
|
|
s.urn,
|
|
|
|
|
s.local_authority_code * 1000 + s.establishment_number as laestab,
|
|
|
|
|
s.school_name,
|
2026-04-01 16:18:52 +01:00
|
|
|
case
|
2026-04-07 21:15:54 +01:00
|
|
|
-- 1. Trust GIAS phase when it's a real value (not the catch-all "Not Applicable")
|
|
|
|
|
when s.phase is not null
|
|
|
|
|
and lower(trim(s.phase)) not in ('not applicable', '', 'unknown')
|
|
|
|
|
then s.phase
|
|
|
|
|
-- 2. Infer from statutory age range (independent schools still publish these)
|
2026-04-01 16:18:52 +01:00
|
|
|
when s.statutory_high_age is not null and s.statutory_high_age <= 11 then 'Primary'
|
|
|
|
|
when s.statutory_low_age is not null and s.statutory_low_age >= 11 then 'Secondary'
|
|
|
|
|
when s.statutory_low_age is not null and s.statutory_high_age is not null
|
|
|
|
|
and s.statutory_low_age < 11 and s.statutory_high_age > 11 then 'All-through'
|
2026-04-07 21:15:54 +01:00
|
|
|
-- 3. Fallback: infer from school name (covers independents with missing ages)
|
|
|
|
|
when s.school_name ilike '%primary%'
|
|
|
|
|
or s.school_name ilike '%infant%'
|
|
|
|
|
or s.school_name ilike '%junior%'
|
|
|
|
|
or s.school_name ilike '%preparatory%'
|
|
|
|
|
or s.school_name ilike '% prep school%'
|
|
|
|
|
or s.school_name ilike '% prep %'
|
|
|
|
|
then 'Primary'
|
|
|
|
|
when s.school_name ilike '%secondary%'
|
|
|
|
|
or s.school_name ilike '%high school%'
|
|
|
|
|
or s.school_name ilike '%grammar%'
|
|
|
|
|
or s.school_name ilike '%senior school%'
|
|
|
|
|
or s.school_name ilike '%upper school%'
|
|
|
|
|
then 'Secondary'
|
|
|
|
|
-- 4. Give up — leave phase null so the UI renders no pill
|
|
|
|
|
else null
|
2026-04-01 16:18:52 +01:00
|
|
|
end as phase,
|
2026-03-26 08:37:53 +00:00
|
|
|
s.school_type,
|
|
|
|
|
s.academy_trust_name,
|
|
|
|
|
s.academy_trust_uid,
|
|
|
|
|
s.religious_character,
|
|
|
|
|
s.gender,
|
|
|
|
|
s.statutory_low_age || '-' || s.statutory_high_age as age_range,
|
|
|
|
|
s.capacity,
|
|
|
|
|
s.total_pupils,
|
|
|
|
|
concat_ws(' ', s.head_title, s.head_first_name, s.head_last_name) as headteacher_name,
|
|
|
|
|
s.website,
|
|
|
|
|
s.telephone,
|
|
|
|
|
s.open_date,
|
|
|
|
|
s.close_date,
|
|
|
|
|
s.status,
|
|
|
|
|
s.nursery_provision,
|
|
|
|
|
s.admissions_policy,
|
|
|
|
|
|
2026-03-26 20:43:24 +00:00
|
|
|
-- Latest Ofsted (populated after monthly Ofsted pipeline runs)
|
|
|
|
|
{% if ofsted_relation is not none %}
|
2026-03-26 08:37:53 +00:00
|
|
|
o.overall_effectiveness as ofsted_grade,
|
|
|
|
|
o.inspection_date as ofsted_date,
|
|
|
|
|
o.framework as ofsted_framework
|
2026-03-26 20:43:24 +00:00
|
|
|
{% else %}
|
|
|
|
|
null::text as ofsted_grade,
|
|
|
|
|
null::date as ofsted_date,
|
|
|
|
|
null::text as ofsted_framework
|
|
|
|
|
{% endif %}
|
2026-03-26 08:37:53 +00:00
|
|
|
|
|
|
|
|
from schools s
|
2026-03-26 20:43:24 +00:00
|
|
|
{% if ofsted_relation is not none %}
|
|
|
|
|
left join {{ ref('int_ofsted_latest') }} o on s.urn = o.urn
|
|
|
|
|
{% endif %}
|
2026-03-26 08:37:53 +00:00
|
|
|
where s.status = 'Open'
|