Skip to content

Commit

Permalink
fix: improve insert of concept and observation records
Browse files Browse the repository at this point in the history
  • Loading branch information
pieterlukasse committed Oct 4, 2024
1 parent 94c1dd0 commit 98c0520
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 6 deletions.
31 changes: 25 additions & 6 deletions tests/data_generator/datagenerator.go
Original file line number Diff line number Diff line change
Expand Up @@ -241,9 +241,7 @@ func AddConceptAndMaybeAddObservations(nextConceptId int64, concept Concept) {
}
vocabularyId := 124 // just use "OMOP Vocabulary" for now...
// If concept id was already added in this session before, skip inserting it:
if utils.Pos(conceptId, conceptIds) == -1 {
// just in case, remove it if it already exists in DB:
tests.RemoveConcept(models.Omop, conceptId)
if utils.Pos(conceptId, conceptIds) == -1 && !tests.ConceptExists(models.Omop, conceptId) {
// add:
tests.ExecSQLStringOrFail(
fmt.Sprintf(
Expand Down Expand Up @@ -292,7 +290,7 @@ func AddObservationForPerson(conceptId int64, concept Concept, personId int64) {
}
valueAsConceptId = concept.PossibleValues[randIndex]
}
tests.ExecSQLStringOrFail(
result := tests.ExecSQLString(
fmt.Sprintf(
"INSERT into %s.observation "+
"(observation_id,person_id,observation_concept_id,value_as_concept_id,value_as_number,observation_date,observation_datetime,observation_type_concept_id) "+
Expand All @@ -301,9 +299,20 @@ func AddObservationForPerson(conceptId int64, concept Concept, personId int64) {
tests.GetOmopDataSourceForSourceId(sourceId).Schema,
lastObservationId+1, personId, conceptId, valueAsConceptId, valueAsNumber),
sourceId)
if result.Error != nil {
// fallback, try simpler record without explicitly setting observation_id:
tests.ExecSQLStringOrFail(fmt.Sprintf(
"INSERT into %s.observation "+
"(person_id,observation_concept_id,value_as_concept_id,value_as_number,observation_date,observation_datetime,observation_type_concept_id) "+
"values "+
"(%d,%d,%s,%s,'2000-01-01','2000-01-01 00:00:00',0)",
tests.GetOmopDataSourceForSourceId(sourceId).Schema,
personId, conceptId, valueAsConceptId, valueAsNumber),
sourceId)
}

// add observation period as well:
tests.ExecSQLStringOrFail(
result = tests.ExecSQLString(
fmt.Sprintf(
"INSERT into %s.observation_period "+
"(observation_period_id,person_id,observation_period_start_date,observation_period_end_date,period_type_concept_id) "+
Expand All @@ -312,7 +321,17 @@ func AddObservationForPerson(conceptId int64, concept Concept, personId int64) {
tests.GetOmopDataSourceForSourceId(sourceId).Schema,
lastObservationId+1, personId),
sourceId)

if result.Error != nil {
// fallback, try simpler record without explicitly setting observation_id:
tests.ExecSQLStringOrFail(fmt.Sprintf(
"INSERT into %s.observation_period "+
"(person_id,observation_period_start_date,observation_period_end_date,period_type_concept_id) "+
"values "+
"(%d,'1999-01-01','2099-01-01',0)",
tests.GetOmopDataSourceForSourceId(sourceId).Schema,
personId),
sourceId)
}
lastObservationId++
countObservations++
}
Expand Down
8 changes: 8 additions & 0 deletions tests/testutils.go
Original file line number Diff line number Diff line change
Expand Up @@ -194,6 +194,14 @@ func RemoveConcept(sourceType models.SourceType, conceptId int64) {
" where concept_id =%v", conceptId), GetTestSourceId())
}

func ConceptExists(sourceType models.SourceType, conceptId int64) bool {
dataSource := db.GetAtlasDB()
count := 0
query := fmt.Sprintf("SELECT COUNT(*) FROM %s.concept WHERE concept_id = ?", GetSchemaNameForType(sourceType))
dataSource.Db.Raw(query, conceptId).Scan(&count)
return count > 0
}

func GetInt64AttributeValue[T any](item T, attributeName string) int64 {
r := reflect.ValueOf(item)
f := reflect.Indirect(r).FieldByName(attributeName)
Expand Down

0 comments on commit 98c0520

Please sign in to comment.