From 703d3bb87c89c3084801c2157fc09bccb8a7d08f Mon Sep 17 00:00:00 2001 From: Pascal Brandt Date: Thu, 2 Jan 2020 19:31:46 -0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=98=B8=20Relax=20measure=5Ftime=20require?= =?UTF-8?q?ment=20and=20only=20check=20in=20current=20schema.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../V1.0.3__Create_Observation_view.pg.sql | 25 ++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/src/main/resources/flyway/migrations/postgresql/V1.0.3__Create_Observation_view.pg.sql b/src/main/resources/flyway/migrations/postgresql/V1.0.3__Create_Observation_view.pg.sql index 8d538bf..b44e7f4 100644 --- a/src/main/resources/flyway/migrations/postgresql/V1.0.3__Create_Observation_view.pg.sql +++ b/src/main/resources/flyway/migrations/postgresql/V1.0.3__Create_Observation_view.pg.sql @@ -4,11 +4,14 @@ $$ DECLARE obs_time_exists boolean := false; obs_time_col_string varchar := ''; + measurement_time_exists boolean := false; + measurement_col_string varchar := ''; BEGIN SELECT EXISTS(SELECT table_name FROM information_schema.columns WHERE table_name = 'observation' - AND column_name = 'observation_time') + AND column_name = 'observation_time' + AND table_schema = current_schema()) into obs_time_exists; CASE WHEN obs_time_exists = TRUE @@ -18,13 +21,29 @@ $$ obs_time_col_string = 'observation.observation_datetime::timestamp::time::varchar(10)'; END CASE; + SELECT EXISTS(SELECT table_name + FROM information_schema.columns + WHERE table_name = 'measurement' + AND column_name = 'measurement_time' + AND table_schema = current_schema()) + into measurement_time_exists; + + RAISE NOTICE 'HERE: %', measurement_time_exists; + + CASE WHEN measurement_time_exists = TRUE + THEN + measurement_col_string = 'measurement_time'; + ELSE + measurement_col_string = 'measurement.measurement_datetime::timestamp::time::varchar(10)'; + END CASE; + EXECUTE $sql$ CREATE view f_observation_view AS SELECT measurement.measurement_id AS observation_id, measurement.person_id, measurement.measurement_concept_id AS observation_concept_id, measurement.measurement_date AS observation_date, - measurement.measurement_time AS observation_time, + $sql$ || measurement_col_string || $sql$ AS observation_time, measurement.measurement_type_concept_id AS observation_type_concept_id, measurement.operator_concept_id AS observation_operator_concept_id, measurement.value_as_number, @@ -74,4 +93,4 @@ $$ ((c.invalid_reason) :: text <> 'D' :: text))))) $sql$; END create_observation_view -$$; \ No newline at end of file +$$;