diff --git a/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java b/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java index 4dea725e2cd3588043d5536ff6a167ff22fc5fa0..f692d96507b09296a41252ba494b35c1457e74a9 100644 --- a/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java +++ b/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java @@ -265,7 +265,7 @@ public class TabFileLoader<T> { ILine<String> line = lineIterator.next(); String text = line.getText(); - if (DEFAULT_SECTION.equals(text)) + if (DEFAULT_SECTION.equals(text.trim())) { break; } @@ -414,7 +414,7 @@ public class TabFileLoader<T> private static boolean startsDefaultSection(ILine<String> line) { String text = line.getText(); - return DEFAULT_SECTION.equals(text); + return DEFAULT_SECTION.equals(text.trim()); } private static boolean startsWithComment(ILine<String> line) diff --git a/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java b/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java index d4003a07b25b8aca035691f9470c8c7c16296bed..f0690ef2a3bb54189ca094cb7422e6d0c4bc96b8 100644 --- a/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java +++ b/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java @@ -108,7 +108,7 @@ public class SampleRegisteringDropbox implements IDataSetHandler new NamedInputStream(new FileInputStream(file), file.getName()); BatchSamplesOperation info = SampleUploadSectionsParser.prepareSamples(sampleType, Arrays.asList(stream), - defaultSpaceIdentifierOrNull, sampleCodeGeneratorOrNull, true, + defaultSpaceIdentifierOrNull, sampleCodeGeneratorOrNull, true, null, BatchOperationKind.REGISTRATION); logSamplesExtracted(file, info); service.registerSamples(info.getSamples(), userOrNull); diff --git a/openbis/.settings/.gitignore b/openbis/.settings/.gitignore deleted file mode 100644 index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..0000000000000000000000000000000000000000 diff --git a/openbis/.settings/org.eclipse.jdt.ui.prefs b/openbis/.settings/org.eclipse.jdt.ui.prefs new file mode 100644 index 0000000000000000000000000000000000000000..954b0282f418a61dee15bbddd3720a6fbf0028ab --- /dev/null +++ b/openbis/.settings/org.eclipse.jdt.ui.prefs @@ -0,0 +1,55 @@ +#Wed Apr 20 13:05:19 CEST 2011 +eclipse.preferences.version=1 +editor_save_participant_org.eclipse.jdt.ui.postsavelistener.cleanup=true +sp_cleanup.add_default_serial_version_id=true +sp_cleanup.add_generated_serial_version_id=false +sp_cleanup.add_missing_annotations=true +sp_cleanup.add_missing_deprecated_annotations=true +sp_cleanup.add_missing_methods=false +sp_cleanup.add_missing_nls_tags=false +sp_cleanup.add_missing_override_annotations=true +sp_cleanup.add_missing_override_annotations_interface_methods=true +sp_cleanup.add_serial_version_id=false +sp_cleanup.always_use_blocks=true +sp_cleanup.always_use_parentheses_in_expressions=false +sp_cleanup.always_use_this_for_non_static_field_access=false +sp_cleanup.always_use_this_for_non_static_method_access=false +sp_cleanup.convert_to_enhanced_for_loop=false +sp_cleanup.correct_indentation=false +sp_cleanup.format_source_code=true +sp_cleanup.format_source_code_changes_only=false +sp_cleanup.make_local_variable_final=false +sp_cleanup.make_parameters_final=false +sp_cleanup.make_private_fields_final=true +sp_cleanup.make_type_abstract_if_missing_method=false +sp_cleanup.make_variable_declarations_final=true +sp_cleanup.never_use_blocks=false +sp_cleanup.never_use_parentheses_in_expressions=true +sp_cleanup.on_save_use_additional_actions=false +sp_cleanup.organize_imports=true +sp_cleanup.qualify_static_field_accesses_with_declaring_class=false +sp_cleanup.qualify_static_member_accesses_through_instances_with_declaring_class=true +sp_cleanup.qualify_static_member_accesses_through_subtypes_with_declaring_class=true +sp_cleanup.qualify_static_member_accesses_with_declaring_class=false +sp_cleanup.qualify_static_method_accesses_with_declaring_class=false +sp_cleanup.remove_private_constructors=true +sp_cleanup.remove_trailing_whitespaces=false +sp_cleanup.remove_trailing_whitespaces_all=true +sp_cleanup.remove_trailing_whitespaces_ignore_empty=false +sp_cleanup.remove_unnecessary_casts=true +sp_cleanup.remove_unnecessary_nls_tags=false +sp_cleanup.remove_unused_imports=false +sp_cleanup.remove_unused_local_variables=false +sp_cleanup.remove_unused_private_fields=true +sp_cleanup.remove_unused_private_members=false +sp_cleanup.remove_unused_private_methods=true +sp_cleanup.remove_unused_private_types=true +sp_cleanup.sort_members=false +sp_cleanup.sort_members_all=false +sp_cleanup.use_blocks=false +sp_cleanup.use_blocks_only_for_return_and_throw=false +sp_cleanup.use_parentheses_in_expressions=false +sp_cleanup.use_this_for_non_static_field_access=false +sp_cleanup.use_this_for_non_static_field_access_only_if_necessary=true +sp_cleanup.use_this_for_non_static_method_access=false +sp_cleanup.use_this_for_non_static_method_access_only_if_necessary=true diff --git a/openbis/results.txt b/openbis/results.txt new file mode 100644 index 0000000000000000000000000000000000000000..9ebdbb4e845eaed00dfbc16baeefa585faa9f379 --- /dev/null +++ b/openbis/results.txt @@ -0,0 +1,31526 @@ +./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-012-013.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-013-014.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-016-017.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-018-019.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-022-023.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-023-024.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-024-025.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-025-026.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-025-026.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base: LANGUAGE plpgsql; +./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base: LANGUAGE plpgsql; +./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-027-028.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-028-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-028-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-028-029.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-029-030.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-030-031.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-031-032.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-040-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-040-041.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-052-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-052-053.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-053-054.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-055-056.sql.svn-base:$$ LANGUAGE plpgsql; +./source/sql/postgresql/migration/.svn/text-base/migration-055-056.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-058-059.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-061-062.sql.svn-base: LANGUAGE plpgsql +./source/sql/postgresql/migration/.svn/text-base/migration-061-062.sql.svn-base: LANGUAGE plpgsql +./source/sql/postgresql/migration/.svn/text-base/migration-065-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-065-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-065-066.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-012-013.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-013-014.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-016-017.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-018-019.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-022-023.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-023-024.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-024-025.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-025-026.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-025-026.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-026-027.sql: LANGUAGE plpgsql; +./source/sql/postgresql/migration/migration-026-027.sql: LANGUAGE plpgsql; +./source/sql/postgresql/migration/migration-026-027.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-026-027.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-027-028.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-028-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-028-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-028-029.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-029-030.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-030-031.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-031-032.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql'; +./source/sql/postgresql/migration/migration-040-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-040-041.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-052-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-052-053.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-053-054.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-055-056.sql:$$ LANGUAGE plpgsql; +./source/sql/postgresql/migration/migration-055-056.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-058-059.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-061-062.sql: LANGUAGE plpgsql +./source/sql/postgresql/migration/migration-061-062.sql: LANGUAGE plpgsql +./source/sql/postgresql/migration/migration-065-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-065-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-065-066.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql'; +./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql'; +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java: + "CREATE PROCEDURAL LANGUAGE plpgsql;\n" +./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2008-01-05 14:51:36.56 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:013 source/sql/postgresql/migration/migration-012-013.sql SUCCESS 2008-05-09 10:11:20.487 ----------------------------------------------------------------------------------------------\\012-- File: migration-012-013.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 012 to 013.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table SAMPLES in order to allow invalidation of samples \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type BACTERIUM\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'BACTERIUM')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012 -----------------------\\012 -- Material Type COMPOUND\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'COMPOUND')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012 \N +./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:014 source/sql/postgresql/migration/migration-013-014.sql SUCCESS 2008-05-09 10:11:22.523 ----------------------------------------------------------------------------------------------\\012-- File: migration-013-014.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 013 to 014.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012-- the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012-- Purpose: Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column COVO_ID to table PROPERTY_TYPES \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 cnt INTEGER;\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Insert into the table DATA_TYPES\\012--\\012-- Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012-- Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012-- to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012-- This results in having all CONTROL_LAYOUTs being directly linked \\012-- to CELL_PLATEs. \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012 SET samp_id_control_layout = \\012 (select control_layout.samp_id\\012 from sample_inputs control_layout inner join samples s \\012 on control_layout.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 and proc_id = (\\012 select proc_id\\012 from sample_inputs cp\\012 where cp.samp_id = cell_plate.id))\\012 WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012 and id = (select distinct (samp_id)\\012 from sample_inputs sain inner join samples s2 \\012 on sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012-- Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where id in (select si.id \\012 from sample_inputs si inner join samples s \\012 on si.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 )\\012;\\012\\012 \N +./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:016 source/sql/postgresql/migration/migration-015-016.sql SUCCESS 2008-05-09 10:12:52.062 ----------------------------------------------------------------------------------------------\\012-- File: migration-015-016.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 015 to 016.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012-- and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012-- This adds time zone information and allows for a clean separation between registration time stamps\\012-- which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012-- to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012BEGIN\\012 FOR rec IN SELECT * FROM data LOOP\\012 rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012 update data set code=rec.code where id=rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != '.STORAGE_FORMAT' then\\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012 ( id\\012 , code\\012 , description\\012 , pers_id_registerer\\012 , is_managed_internally )\\012values (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012 , '.STORAGE_FORMAT'\\012 , 'The on-disk storage format of a data set'\\012 , (select id from persons where user_id ='system')\\012 , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'PROPRIETARY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'BDS_DIRECTORY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012-- Purpose: Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012-- Purpose: Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012 dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012 select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012 where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012 update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 meas_ts TIMESTAMP;\\012 ds_code CODE;\\012 meas_ts_str TEXT;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code; \\012 FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012 meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012 ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012 IF meas_ts_str is not null and ds_code is not null THEN\\012 meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012 update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012 END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012 IF ts1 < ts2 THEN\\012 RETURN ts2 - ts1;\\012 ELSE\\012 RETURN ts1 - ts2;\\012 END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012 source_id TECH_ID;\\012 rec_derived RECORD;\\012 rec_acquired RECORD;\\012 rel_location TEXT;\\012 data_set_code TEXT;\\012 data_set_code_trial TEXT;\\012 loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 count INTEGER := 0;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code;\\012 FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012 source_id := NULL;\\012 select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012 IF rel_location is not null then\\012 data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code is not null THEN\\012 FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012 select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012 IF rel_location is not null THEN\\012 data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code_trial = data_set_code THEN\\012 source_id = rec_acquired.id;\\012 EXIT;\\012 END IF;\\012 END IF;\\012 END LOOP;\\012 END IF;\\012 END IF;\\012 -- If the location didn't tell us about data set relationships, try the backup strategy.\\012 IF source_id is null THEN\\012 -- Use the measured data set as source that is closest in registration timestamp.\\012 select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012 and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012 = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012 from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012 END IF;\\012 IF source_id is not null THEN\\012 insert into data_set_relationships (id, data_id_parent, data_id_child)\\012 values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012 count := count + 1;\\012 END IF;\\012 END LOOP;\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012-- properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 cnt INTEGER := 0;\\012 already_exists INTEGER;\\012 new_label TEXT;\\012 this_id TECH_ID;\\012BEGIN\\012 FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012 IF this_key = prev_key THEN\\012 dup_count := dup_count + 1;\\012 cnt := cnt + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_label := this_key || '(' || dup_count::text || ')';\\012 select count(*) into already_exists from property_types where label = new_label;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 update property_types set label = new_label where id = this_id;\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '96_WELLS_8X12'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '1536_WELLS_32X48'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012-- and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012-- and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012 where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012 or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012 || ' order by upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key);\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 prev_key2 TECH_ID;\\012 this_key TEXT;\\012 this_key2 TECH_ID;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012 || ' order by ' || clm2 || ',upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012 || clm2 || ' = ' || quote_literal(this_key2);\\012 END IF;\\012 prev_key := this_key;\\012 prev_key2 := this_key2;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Delete sample_components with no associated material_batches.\\012-- This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where id in (select sc.id \\012 from sample_components as sc left join sample_component_materials as scm \\012 on scm.saco_id = sc.id \\012 where scm.saco_id is null\\012 )\\012;\\012 \N +./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:017 source/sql/postgresql/migration/migration-016-017.sql SUCCESS 2008-05-09 10:12:57.473 ----------------------------------------------------------------------------------------------\\012-- File: migration-016-017.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 016 to 017.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011 When\\011\\011 What\\012--\\011---\\011\\011\\011 ---- \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012-- Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012-- CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type SIRNHACS\\012 -----------------------\\012\\012insert into experiment_type_property_types\\012( id\\012 ,exty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,is_managed_internally\\012 ,pers_id_registerer\\012 )\\012values \\012( nextval('ETPT_ID_SEQ')\\012 ,(select id from experiment_types where code = 'SIRNAHCS')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012( id\\012 ,expe_id\\012 ,value\\012 ,etpt_id\\012 ,pers_id_registerer\\012)\\012select\\012 nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012 ,id\\012 ,case when description is not null then description else 'No description given' end\\012 ,currval('ETPT_ID_SEQ')\\012 ,(select id from persons where user_id ='system') \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012 \N +./sourceTest/sql/postgresql/018/.svn/text-base/schema-018.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/018/.svn/text-base/schema-018.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/018/.svn/text-base/schema-018.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2008-01-05 14:51:36.56 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:013 source/sql/postgresql/migration/migration-012-013.sql SUCCESS 2008-05-09 10:11:20.487 ----------------------------------------------------------------------------------------------\\012-- File: migration-012-013.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 012 to 013.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table SAMPLES in order to allow invalidation of samples \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type BACTERIUM\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'BACTERIUM')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012 -----------------------\\012 -- Material Type COMPOUND\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'COMPOUND')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012 \N +./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:014 source/sql/postgresql/migration/migration-013-014.sql SUCCESS 2008-05-09 10:11:22.523 ----------------------------------------------------------------------------------------------\\012-- File: migration-013-014.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 013 to 014.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012-- the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012-- Purpose: Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column COVO_ID to table PROPERTY_TYPES \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 cnt INTEGER;\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Insert into the table DATA_TYPES\\012--\\012-- Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012-- Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012-- to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012-- This results in having all CONTROL_LAYOUTs being directly linked \\012-- to CELL_PLATEs. \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012 SET samp_id_control_layout = \\012 (select control_layout.samp_id\\012 from sample_inputs control_layout inner join samples s \\012 on control_layout.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 and proc_id = (\\012 select proc_id\\012 from sample_inputs cp\\012 where cp.samp_id = cell_plate.id))\\012 WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012 and id = (select distinct (samp_id)\\012 from sample_inputs sain inner join samples s2 \\012 on sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012-- Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where id in (select si.id \\012 from sample_inputs si inner join samples s \\012 on si.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 )\\012;\\012\\012 \N +./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:016 source/sql/postgresql/migration/migration-015-016.sql SUCCESS 2008-05-09 10:12:52.062 ----------------------------------------------------------------------------------------------\\012-- File: migration-015-016.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 015 to 016.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012-- and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012-- This adds time zone information and allows for a clean separation between registration time stamps\\012-- which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012-- to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012BEGIN\\012 FOR rec IN SELECT * FROM data LOOP\\012 rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012 update data set code=rec.code where id=rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != '.STORAGE_FORMAT' then\\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012 ( id\\012 , code\\012 , description\\012 , pers_id_registerer\\012 , is_managed_internally )\\012values (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012 , '.STORAGE_FORMAT'\\012 , 'The on-disk storage format of a data set'\\012 , (select id from persons where user_id ='system')\\012 , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'PROPRIETARY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'BDS_DIRECTORY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012-- Purpose: Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012-- Purpose: Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012 dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012 select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012 where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012 update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 meas_ts TIMESTAMP;\\012 ds_code CODE;\\012 meas_ts_str TEXT;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code; \\012 FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012 meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012 ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012 IF meas_ts_str is not null and ds_code is not null THEN\\012 meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012 update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012 END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012 IF ts1 < ts2 THEN\\012 RETURN ts2 - ts1;\\012 ELSE\\012 RETURN ts1 - ts2;\\012 END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012 source_id TECH_ID;\\012 rec_derived RECORD;\\012 rec_acquired RECORD;\\012 rel_location TEXT;\\012 data_set_code TEXT;\\012 data_set_code_trial TEXT;\\012 loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 count INTEGER := 0;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code;\\012 FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012 source_id := NULL;\\012 select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012 IF rel_location is not null then\\012 data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code is not null THEN\\012 FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012 select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012 IF rel_location is not null THEN\\012 data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code_trial = data_set_code THEN\\012 source_id = rec_acquired.id;\\012 EXIT;\\012 END IF;\\012 END IF;\\012 END LOOP;\\012 END IF;\\012 END IF;\\012 -- If the location didn't tell us about data set relationships, try the backup strategy.\\012 IF source_id is null THEN\\012 -- Use the measured data set as source that is closest in registration timestamp.\\012 select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012 and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012 = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012 from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012 END IF;\\012 IF source_id is not null THEN\\012 insert into data_set_relationships (id, data_id_parent, data_id_child)\\012 values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012 count := count + 1;\\012 END IF;\\012 END LOOP;\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012-- properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 cnt INTEGER := 0;\\012 already_exists INTEGER;\\012 new_label TEXT;\\012 this_id TECH_ID;\\012BEGIN\\012 FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012 IF this_key = prev_key THEN\\012 dup_count := dup_count + 1;\\012 cnt := cnt + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_label := this_key || '(' || dup_count::text || ')';\\012 select count(*) into already_exists from property_types where label = new_label;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 update property_types set label = new_label where id = this_id;\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '96_WELLS_8X12'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '1536_WELLS_32X48'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012-- and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012-- and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012 where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012 or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012 || ' order by upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key);\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 prev_key2 TECH_ID;\\012 this_key TEXT;\\012 this_key2 TECH_ID;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012 || ' order by ' || clm2 || ',upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012 || clm2 || ' = ' || quote_literal(this_key2);\\012 END IF;\\012 prev_key := this_key;\\012 prev_key2 := this_key2;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Delete sample_components with no associated material_batches.\\012-- This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where id in (select sc.id \\012 from sample_components as sc left join sample_component_materials as scm \\012 on scm.saco_id = sc.id \\012 where scm.saco_id is null\\012 )\\012;\\012 \N +./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:017 source/sql/postgresql/migration/migration-016-017.sql SUCCESS 2008-05-09 10:12:57.473 ----------------------------------------------------------------------------------------------\\012-- File: migration-016-017.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 016 to 017.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011 When\\011\\011 What\\012--\\011---\\011\\011\\011 ---- \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012-- Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012-- CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type SIRNHACS\\012 -----------------------\\012\\012insert into experiment_type_property_types\\012( id\\012 ,exty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,is_managed_internally\\012 ,pers_id_registerer\\012 )\\012values \\012( nextval('ETPT_ID_SEQ')\\012 ,(select id from experiment_types where code = 'SIRNAHCS')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012( id\\012 ,expe_id\\012 ,value\\012 ,etpt_id\\012 ,pers_id_registerer\\012)\\012select\\012 nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012 ,id\\012 ,case when description is not null then description else 'No description given' end\\012 ,currval('ETPT_ID_SEQ')\\012 ,(select id from persons where user_id ='system') \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012 \N +./sourceTest/sql/postgresql/018/schema-018.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/018/schema-018.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/018/schema-018.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/019/.svn/text-base/schema-019.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/019/.svn/text-base/schema-019.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/019/.svn/text-base/schema-019.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/019/schema-019.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/019/schema-019.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/019/schema-019.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/020/.svn/text-base/schema-020.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/020/.svn/text-base/schema-020.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/020/.svn/text-base/schema-020.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/020/schema-020.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/020/schema-020.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/020/schema-020.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/021/.svn/text-base/schema-021.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/021/.svn/text-base/schema-021.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/021/.svn/text-base/schema-021.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/021/schema-021.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/021/schema-021.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/021/schema-021.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/022/.svn/text-base/schema-022.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/022/.svn/text-base/schema-022.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/022/.svn/text-base/schema-022.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/022/schema-022.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/022/schema-022.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/022/schema-022.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/023/.svn/text-base/schema-023.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/023/.svn/text-base/schema-023.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/023/.svn/text-base/schema-023.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/023/schema-023.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/023/schema-023.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/023/schema-023.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/schema-024.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/schema-024.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/schema-024.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/024/schema-024.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/schema-025.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/schema-025.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/schema-025.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/schema-025.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/025/schema-025.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2008-01-05 14:51:36.56 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:013 source/sql/postgresql/migration/migration-012-013.sql SUCCESS 2008-05-09 10:11:20.487 ----------------------------------------------------------------------------------------------\\012-- File: migration-012-013.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 012 to 013.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table SAMPLES in order to allow invalidation of samples \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type BACTERIUM\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'BACTERIUM')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012 -----------------------\\012 -- Material Type COMPOUND\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'COMPOUND')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:014 source/sql/postgresql/migration/migration-013-014.sql SUCCESS 2008-05-09 10:11:22.523 ----------------------------------------------------------------------------------------------\\012-- File: migration-013-014.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 013 to 014.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012-- the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012-- Purpose: Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column COVO_ID to table PROPERTY_TYPES \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 cnt INTEGER;\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Insert into the table DATA_TYPES\\012--\\012-- Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012-- Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012-- to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012-- This results in having all CONTROL_LAYOUTs being directly linked \\012-- to CELL_PLATEs. \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012 SET samp_id_control_layout = \\012 (select control_layout.samp_id\\012 from sample_inputs control_layout inner join samples s \\012 on control_layout.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 and proc_id = (\\012 select proc_id\\012 from sample_inputs cp\\012 where cp.samp_id = cell_plate.id))\\012 WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012 and id = (select distinct (samp_id)\\012 from sample_inputs sain inner join samples s2 \\012 on sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012-- Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where id in (select si.id \\012 from sample_inputs si inner join samples s \\012 on si.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 )\\012;\\012\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:016 source/sql/postgresql/migration/migration-015-016.sql SUCCESS 2008-05-09 10:12:52.062 ----------------------------------------------------------------------------------------------\\012-- File: migration-015-016.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 015 to 016.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012-- and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012-- This adds time zone information and allows for a clean separation between registration time stamps\\012-- which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012-- to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012BEGIN\\012 FOR rec IN SELECT * FROM data LOOP\\012 rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012 update data set code=rec.code where id=rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != '.STORAGE_FORMAT' then\\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012 ( id\\012 , code\\012 , description\\012 , pers_id_registerer\\012 , is_managed_internally )\\012values (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012 , '.STORAGE_FORMAT'\\012 , 'The on-disk storage format of a data set'\\012 , (select id from persons where user_id ='system')\\012 , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'PROPRIETARY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'BDS_DIRECTORY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012-- Purpose: Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012-- Purpose: Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012 dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012 select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012 where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012 update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 meas_ts TIMESTAMP;\\012 ds_code CODE;\\012 meas_ts_str TEXT;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code; \\012 FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012 meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012 ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012 IF meas_ts_str is not null and ds_code is not null THEN\\012 meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012 update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012 END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012 IF ts1 < ts2 THEN\\012 RETURN ts2 - ts1;\\012 ELSE\\012 RETURN ts1 - ts2;\\012 END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012 source_id TECH_ID;\\012 rec_derived RECORD;\\012 rec_acquired RECORD;\\012 rel_location TEXT;\\012 data_set_code TEXT;\\012 data_set_code_trial TEXT;\\012 loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 count INTEGER := 0;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code;\\012 FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012 source_id := NULL;\\012 select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012 IF rel_location is not null then\\012 data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code is not null THEN\\012 FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012 select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012 IF rel_location is not null THEN\\012 data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code_trial = data_set_code THEN\\012 source_id = rec_acquired.id;\\012 EXIT;\\012 END IF;\\012 END IF;\\012 END LOOP;\\012 END IF;\\012 END IF;\\012 -- If the location didn't tell us about data set relationships, try the backup strategy.\\012 IF source_id is null THEN\\012 -- Use the measured data set as source that is closest in registration timestamp.\\012 select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012 and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012 = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012 from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012 END IF;\\012 IF source_id is not null THEN\\012 insert into data_set_relationships (id, data_id_parent, data_id_child)\\012 values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012 count := count + 1;\\012 END IF;\\012 END LOOP;\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012-- properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 cnt INTEGER := 0;\\012 already_exists INTEGER;\\012 new_label TEXT;\\012 this_id TECH_ID;\\012BEGIN\\012 FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012 IF this_key = prev_key THEN\\012 dup_count := dup_count + 1;\\012 cnt := cnt + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_label := this_key || '(' || dup_count::text || ')';\\012 select count(*) into already_exists from property_types where label = new_label;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 update property_types set label = new_label where id = this_id;\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '96_WELLS_8X12'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '1536_WELLS_32X48'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012-- and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012-- and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012 where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012 or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012 || ' order by upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key);\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 prev_key2 TECH_ID;\\012 this_key TEXT;\\012 this_key2 TECH_ID;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012 || ' order by ' || clm2 || ',upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012 || clm2 || ' = ' || quote_literal(this_key2);\\012 END IF;\\012 prev_key := this_key;\\012 prev_key2 := this_key2;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Delete sample_components with no associated material_batches.\\012-- This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where id in (select sc.id \\012 from sample_components as sc left join sample_component_materials as scm \\012 on scm.saco_id = sc.id \\012 where scm.saco_id is null\\012 )\\012;\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:017 source/sql/postgresql/migration/migration-016-017.sql SUCCESS 2008-05-09 10:12:57.473 ----------------------------------------------------------------------------------------------\\012-- File: migration-016-017.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 016 to 017.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011 When\\011\\011 What\\012--\\011---\\011\\011\\011 ---- \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012-- Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012-- CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type SIRNHACS\\012 -----------------------\\012\\012insert into experiment_type_property_types\\012( id\\012 ,exty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,is_managed_internally\\012 ,pers_id_registerer\\012 )\\012values \\012( nextval('ETPT_ID_SEQ')\\012 ,(select id from experiment_types where code = 'SIRNAHCS')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012( id\\012 ,expe_id\\012 ,value\\012 ,etpt_id\\012 ,pers_id_registerer\\012)\\012select\\012 nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012 ,id\\012 ,case when description is not null then description else 'No description given' end\\012 ,currval('ETPT_ID_SEQ')\\012 ,(select id from persons where user_id ='system') \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:023 ../openbis/source/sql/postgresql/migration/migration-022-023.sql SUCCESS 2008-09-15 14:46:19.697 -- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom022To023\\012\\012-- Add column GLOBAL_CODE to the DATABASE_INSTANCES table.\\012-- Set it's value from the code, it will be updated later from java.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN GLOBAL_CODE CODE;\\012update DATABASE_INSTANCES set GLOBAL_CODE = CODE;\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_GLOBAL_CODE_UK UNIQUE(GLOBAL_CODE);\\012ALTER TABLE DATABASE_INSTANCES alter column GLOBAL_CODE set NOT NULL;\\012\\012-- Add column the new FK column SAMP_ID_PART_OF of the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD COLUMN SAMP_ID_PART_OF TECH_ID;\\012\\012-- Drop constraint SAMP_BK_DBIN_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_DBIN_UK;\\012\\012-- Drop constraint SAMP_BK_GROU_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_GROU_UK;\\012\\012-- Add FK PART_OF to the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_PART_OF FOREIGN KEY (SAMP_ID_PART_OF) REFERENCES SAMPLES(ID);\\012\\012-- Add Index for the FK Part Of of the SAMPLES table\\012CREATE INDEX SAMP_SAMP_FK_I_PART_OF ON SAMPLES (SAMP_ID_PART_OF);\\012\\012-- Create the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE TABLE SAMPLE_MATERIAL_BATCHES (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL);\\012\\012-- Create the sequence for the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012\\012\\012-- Create WELL as a new SAMPLE_TYPE\\012\\012insert into sample_types\\012(id\\012,code\\012,description\\012,dbin_id)\\012values \\012(nextval('SAMPLE_TYPE_ID_SEQ')\\012,'WELL'\\012,'Plate Well'\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012\\012-- Transfer data from the SAMPLE_COMPONENTS table to the SAMPLES table\\012\\012INSERT INTO samples(\\012 id\\012 , code\\012 , samp_id_top\\012 , samp_id_generated_from\\012 , saty_id\\012 , pers_id_registerer\\012 , inva_id\\012 , samp_id_control_layout\\012 , dbin_id\\012 , grou_id\\012 , samp_id_part_of)\\012SELECT nextval('sample_id_seq')\\012 , saco.code\\012 , null\\012 , null\\012 , (select id from sample_types where code = 'WELL')\\012 , (select id from persons where user_id ='system')\\012 , samp.inva_id\\012 , null\\012 , samp.dbin_id\\012 , samp.grou_id\\012 , saco.samp_id\\012FROM samples samp INNER JOIN sample_components saco\\012 ON samp.id = saco.samp_id;\\012\\012\\012-- Fill the SAMPLE_MATERIAL_BATCHES table via SAMPLE_C0MPONENT_MATERIALS, SAMPLE_C0MPONENTS, SAMPLES and MATERIAL_BATCHES tables\\012\\012INSERT INTO sample_material_batches(\\012 id\\012 , samp_id\\012 , maba_id)\\012SELECT nextval('sample_material_batch_id_seq')\\012 , well.id\\012 , scma.maba_id\\012FROM sample_component_materials scma \\012 INNER JOIN material_batches maba\\012 ON scma.maba_id = maba.id\\012 INNER JOIN sample_components saco\\012 ON scma.saco_id = saco.id\\012 INNER JOIN samples well\\012 ON saco.code = well.code and saco.samp_id = well.samp_id_part_of\\012;\\012\\012\\012-- Drop the retired Database Objects\\012\\012DROP TABLE SAMPLE_COMPONENT_MATERIALS;\\012DROP TABLE SAMPLE_COMPONENTS;\\012\\012DROP SEQUENCE SCMA_ID_SEQ;\\012DROP SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:024 ../openbis/source/sql/postgresql/migration/migration-023-024.sql SUCCESS 2008-09-15 14:46:19.886 -- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom023To024\\012\\012-- Drop constraint DBIN_GLOBAL_CODE_UK of DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES DROP CONSTRAINT DBIN_GLOBAL_CODE_UK;\\012\\012-- Name changes\\012\\012ALTER TABLE DATABASE_INSTANCES RENAME COLUMN GLOBAL_CODE TO UUID;\\012\\012-- Add constraint DBIN_UUID_UK to the DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_UUID_UK UNIQUE(UUID);\\012\\012-- Drop column in EXPERIMENTS\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012\\012-- Add index to SAMPLES table\\012\\012CREATE INDEX SAMP_CODE_I ON SAMPLES (CODE);\\012\\012-- Bug fix in trigger function SAMPLE_CODE_UNIQUENESS_CHECK()\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:025 ../openbis/source/sql/postgresql/migration/migration-024-025.sql SUCCESS 2008-09-15 14:46:20.011 -- move screenable plates to a group, because it's no longer possible\\012-- to have such plates on the instance level\\012\\012CREATE OR REPLACE FUNCTION move_exp_samples_to_group() RETURNS integer AS $$\\012DECLARE\\012 sample RECORD;\\012 groupId Integer;\\012BEGIN\\012 FOR sample IN \\012 (SELECT * FROM samples s inner join sample_types t on s.saty_id = t.id \\012\\011where t.code in ('CELL_PLATE', 'REINFECT_PLATE'))\\012 LOOP\\012\\011if (sample.dbin_id is not NULL) THEN\\012\\011\\011select proj.grou_id into groupId from\\012\\011\\011\\011samples sa\\012\\011\\011\\011left outer join sample_inputs si on sa.id = si.samp_id \\012\\011\\011\\011left outer join procedures proc on proc.id = si.proc_id \\012\\011\\011\\011left outer join experiments ex on ex.id = proc.expe_id\\012\\011\\011\\011left outer join projects proj on proj.id = ex.proj_id\\012\\011\\011where sa.id = sample.id;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011select id into groupId from groups limit 1;\\012\\011\\011END IF;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011RAISE EXCEPTION 'There is no group in the database - internal error!';\\012\\011\\011END IF;\\012\\011\\011update samples set grou_id = groupId, dbin_id = NULL\\012\\011\\011 where id = sample.id;\\012\\011END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select move_exp_samples_to_group();\\012\\012-- Create new table DATA_STORES.\\012\\012CREATE TABLE DATA_STORES (ID TECH_ID NOT NULL,DBIN_ID TECH_ID NOT NULL,CODE CODE NOT NULL,DOWNLOAD_URL VARCHAR(1024) NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012CREATE SEQUENCE DATA_STORE_ID_SEQ;\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_BK_UK UNIQUE(CODE,DBIN_ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX DAST_DBIN_FK_I ON DATA_STORES (DBIN_ID);\\012\\012-- Add new column DAST_ID (connection to DATA_STORES table) to tables DATABASE_INSTANCES, GROUPS, PROJECTS, EXPERIMENTS.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE GROUPS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE PROJECTS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD COLUMN DAST_ID TECH_ID;\\012\\012-- Create the STANDARD data store and assign it to the home database instance.\\012 \\012insert into data_stores\\012(id\\012,code\\012,download_url\\012,dbin_id)\\012values \\012(nextval('DATA_STORE_ID_SEQ')\\012,'STANDARD'\\012,''\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012update database_instances set dast_id = (select id from data_stores where code = 'STANDARD') where is_original_source = true;\\012\\012-- Add foreign key constratints.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:026 ../openbis/source/sql/postgresql/migration/migration-025-026.sql SUCCESS 2008-09-15 14:46:20.192 -- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom025To026\\012-- Remove ID column from SAMPLE_INPUTS table\\012DROP SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_sain_pk_constraint() returns void AS $$\\012begin\\012 perform *\\012 FROM information_schema.table_constraints WHERE constraint_name='sain_pk';\\012 if found\\012 then\\012\\011ALTER TABLE SAMPLE_INPUTS DROP CONSTRAINT SAIN_PK;\\012 end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_sain_pk_constraint();\\012drop function remove_sain_pk_constraint();\\012ALTER TABLE SAMPLE_INPUTS DROP COLUMN ID;\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(SAMP_ID,PROC_ID);\\012\\012-- Remove ID column from SAMPLE_MATERIAL_BATCHES table\\012DROP SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_samb_pk_constraint() returns void AS $$\\012begin\\012 perform *\\012 FROM information_schema.table_constraints WHERE constraint_name='SAMB_PK';\\012 if found\\012 then\\012\\012 end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_samb_pk_constraint();\\012drop function remove_samb_pk_constraint();\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES DROP COLUMN ID;\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES ADD CONSTRAINT SAMB_PK PRIMARY KEY(SAMP_ID,MABA_ID);\\012\\012-- Remove ID and REGISTRATION_TIMESTAMP column from DATA_SET_RELATIONSHIPS table\\012DROP SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_PK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_BK_UK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN ID;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN REGISTRATION_TIMESTAMP;\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(DATA_ID_PARENT,DATA_ID_CHILD);\\012\\012-- Rename: \\012-- OBSERVABLE_TYPES -> DATA_SET_TYPES\\012-- OBSERVABLE_TYPE_ID_SEQ -> DATA_SET_TYPE_ID_SEQ\\012-- DATA.OBTY_ID -> DATA.DSTY_ID\\012ALTER TABLE OBSERVABLE_TYPES RENAME TO DATA_SET_TYPES;\\012ALTER TABLE OBSERVABLE_TYPE_ID_SEQ RENAME TO DATA_SET_TYPE_ID_SEQ;\\012ALTER TABLE DATA RENAME COLUMN OBTY_ID TO DSTY_ID;\\012 \N +./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2008-01-05 14:51:36.56 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:013 source/sql/postgresql/migration/migration-012-013.sql SUCCESS 2008-05-09 10:11:20.487 ----------------------------------------------------------------------------------------------\\012-- File: migration-012-013.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 012 to 013.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table SAMPLES in order to allow invalidation of samples \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type BACTERIUM\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'BACTERIUM')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012 -----------------------\\012 -- Material Type COMPOUND\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'COMPOUND')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:014 source/sql/postgresql/migration/migration-013-014.sql SUCCESS 2008-05-09 10:11:22.523 ----------------------------------------------------------------------------------------------\\012-- File: migration-013-014.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 013 to 014.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012-- the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012-- Purpose: Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column COVO_ID to table PROPERTY_TYPES \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 cnt INTEGER;\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Insert into the table DATA_TYPES\\012--\\012-- Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012-- Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012-- to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012-- This results in having all CONTROL_LAYOUTs being directly linked \\012-- to CELL_PLATEs. \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012 SET samp_id_control_layout = \\012 (select control_layout.samp_id\\012 from sample_inputs control_layout inner join samples s \\012 on control_layout.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 and proc_id = (\\012 select proc_id\\012 from sample_inputs cp\\012 where cp.samp_id = cell_plate.id))\\012 WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012 and id = (select distinct (samp_id)\\012 from sample_inputs sain inner join samples s2 \\012 on sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012-- Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where id in (select si.id \\012 from sample_inputs si inner join samples s \\012 on si.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 )\\012;\\012\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:016 source/sql/postgresql/migration/migration-015-016.sql SUCCESS 2008-05-09 10:12:52.062 ----------------------------------------------------------------------------------------------\\012-- File: migration-015-016.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 015 to 016.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012-- and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012-- This adds time zone information and allows for a clean separation between registration time stamps\\012-- which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012-- to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012BEGIN\\012 FOR rec IN SELECT * FROM data LOOP\\012 rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012 update data set code=rec.code where id=rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != '.STORAGE_FORMAT' then\\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012 ( id\\012 , code\\012 , description\\012 , pers_id_registerer\\012 , is_managed_internally )\\012values (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012 , '.STORAGE_FORMAT'\\012 , 'The on-disk storage format of a data set'\\012 , (select id from persons where user_id ='system')\\012 , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'PROPRIETARY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'BDS_DIRECTORY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012-- Purpose: Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012-- Purpose: Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012 dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012 select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012 where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012 update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 meas_ts TIMESTAMP;\\012 ds_code CODE;\\012 meas_ts_str TEXT;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code; \\012 FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012 meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012 ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012 IF meas_ts_str is not null and ds_code is not null THEN\\012 meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012 update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012 END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012 IF ts1 < ts2 THEN\\012 RETURN ts2 - ts1;\\012 ELSE\\012 RETURN ts1 - ts2;\\012 END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012 source_id TECH_ID;\\012 rec_derived RECORD;\\012 rec_acquired RECORD;\\012 rel_location TEXT;\\012 data_set_code TEXT;\\012 data_set_code_trial TEXT;\\012 loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 count INTEGER := 0;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code;\\012 FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012 source_id := NULL;\\012 select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012 IF rel_location is not null then\\012 data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code is not null THEN\\012 FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012 select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012 IF rel_location is not null THEN\\012 data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code_trial = data_set_code THEN\\012 source_id = rec_acquired.id;\\012 EXIT;\\012 END IF;\\012 END IF;\\012 END LOOP;\\012 END IF;\\012 END IF;\\012 -- If the location didn't tell us about data set relationships, try the backup strategy.\\012 IF source_id is null THEN\\012 -- Use the measured data set as source that is closest in registration timestamp.\\012 select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012 and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012 = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012 from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012 END IF;\\012 IF source_id is not null THEN\\012 insert into data_set_relationships (id, data_id_parent, data_id_child)\\012 values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012 count := count + 1;\\012 END IF;\\012 END LOOP;\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012-- properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 cnt INTEGER := 0;\\012 already_exists INTEGER;\\012 new_label TEXT;\\012 this_id TECH_ID;\\012BEGIN\\012 FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012 IF this_key = prev_key THEN\\012 dup_count := dup_count + 1;\\012 cnt := cnt + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_label := this_key || '(' || dup_count::text || ')';\\012 select count(*) into already_exists from property_types where label = new_label;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 update property_types set label = new_label where id = this_id;\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '96_WELLS_8X12'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '1536_WELLS_32X48'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012-- and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012-- and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012 where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012 or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012 || ' order by upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key);\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 prev_key2 TECH_ID;\\012 this_key TEXT;\\012 this_key2 TECH_ID;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012 || ' order by ' || clm2 || ',upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012 || clm2 || ' = ' || quote_literal(this_key2);\\012 END IF;\\012 prev_key := this_key;\\012 prev_key2 := this_key2;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Delete sample_components with no associated material_batches.\\012-- This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where id in (select sc.id \\012 from sample_components as sc left join sample_component_materials as scm \\012 on scm.saco_id = sc.id \\012 where scm.saco_id is null\\012 )\\012;\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:017 source/sql/postgresql/migration/migration-016-017.sql SUCCESS 2008-05-09 10:12:57.473 ----------------------------------------------------------------------------------------------\\012-- File: migration-016-017.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 016 to 017.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011 When\\011\\011 What\\012--\\011---\\011\\011\\011 ---- \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012-- Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012-- CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type SIRNHACS\\012 -----------------------\\012\\012insert into experiment_type_property_types\\012( id\\012 ,exty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,is_managed_internally\\012 ,pers_id_registerer\\012 )\\012values \\012( nextval('ETPT_ID_SEQ')\\012 ,(select id from experiment_types where code = 'SIRNAHCS')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012( id\\012 ,expe_id\\012 ,value\\012 ,etpt_id\\012 ,pers_id_registerer\\012)\\012select\\012 nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012 ,id\\012 ,case when description is not null then description else 'No description given' end\\012 ,currval('ETPT_ID_SEQ')\\012 ,(select id from persons where user_id ='system') \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:023 ../openbis/source/sql/postgresql/migration/migration-022-023.sql SUCCESS 2008-09-15 14:46:19.697 -- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom022To023\\012\\012-- Add column GLOBAL_CODE to the DATABASE_INSTANCES table.\\012-- Set it's value from the code, it will be updated later from java.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN GLOBAL_CODE CODE;\\012update DATABASE_INSTANCES set GLOBAL_CODE = CODE;\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_GLOBAL_CODE_UK UNIQUE(GLOBAL_CODE);\\012ALTER TABLE DATABASE_INSTANCES alter column GLOBAL_CODE set NOT NULL;\\012\\012-- Add column the new FK column SAMP_ID_PART_OF of the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD COLUMN SAMP_ID_PART_OF TECH_ID;\\012\\012-- Drop constraint SAMP_BK_DBIN_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_DBIN_UK;\\012\\012-- Drop constraint SAMP_BK_GROU_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_GROU_UK;\\012\\012-- Add FK PART_OF to the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_PART_OF FOREIGN KEY (SAMP_ID_PART_OF) REFERENCES SAMPLES(ID);\\012\\012-- Add Index for the FK Part Of of the SAMPLES table\\012CREATE INDEX SAMP_SAMP_FK_I_PART_OF ON SAMPLES (SAMP_ID_PART_OF);\\012\\012-- Create the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE TABLE SAMPLE_MATERIAL_BATCHES (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL);\\012\\012-- Create the sequence for the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012\\012\\012-- Create WELL as a new SAMPLE_TYPE\\012\\012insert into sample_types\\012(id\\012,code\\012,description\\012,dbin_id)\\012values \\012(nextval('SAMPLE_TYPE_ID_SEQ')\\012,'WELL'\\012,'Plate Well'\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012\\012-- Transfer data from the SAMPLE_COMPONENTS table to the SAMPLES table\\012\\012INSERT INTO samples(\\012 id\\012 , code\\012 , samp_id_top\\012 , samp_id_generated_from\\012 , saty_id\\012 , pers_id_registerer\\012 , inva_id\\012 , samp_id_control_layout\\012 , dbin_id\\012 , grou_id\\012 , samp_id_part_of)\\012SELECT nextval('sample_id_seq')\\012 , saco.code\\012 , null\\012 , null\\012 , (select id from sample_types where code = 'WELL')\\012 , (select id from persons where user_id ='system')\\012 , samp.inva_id\\012 , null\\012 , samp.dbin_id\\012 , samp.grou_id\\012 , saco.samp_id\\012FROM samples samp INNER JOIN sample_components saco\\012 ON samp.id = saco.samp_id;\\012\\012\\012-- Fill the SAMPLE_MATERIAL_BATCHES table via SAMPLE_C0MPONENT_MATERIALS, SAMPLE_C0MPONENTS, SAMPLES and MATERIAL_BATCHES tables\\012\\012INSERT INTO sample_material_batches(\\012 id\\012 , samp_id\\012 , maba_id)\\012SELECT nextval('sample_material_batch_id_seq')\\012 , well.id\\012 , scma.maba_id\\012FROM sample_component_materials scma \\012 INNER JOIN material_batches maba\\012 ON scma.maba_id = maba.id\\012 INNER JOIN sample_components saco\\012 ON scma.saco_id = saco.id\\012 INNER JOIN samples well\\012 ON saco.code = well.code and saco.samp_id = well.samp_id_part_of\\012;\\012\\012\\012-- Drop the retired Database Objects\\012\\012DROP TABLE SAMPLE_COMPONENT_MATERIALS;\\012DROP TABLE SAMPLE_COMPONENTS;\\012\\012DROP SEQUENCE SCMA_ID_SEQ;\\012DROP SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:024 ../openbis/source/sql/postgresql/migration/migration-023-024.sql SUCCESS 2008-09-15 14:46:19.886 -- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom023To024\\012\\012-- Drop constraint DBIN_GLOBAL_CODE_UK of DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES DROP CONSTRAINT DBIN_GLOBAL_CODE_UK;\\012\\012-- Name changes\\012\\012ALTER TABLE DATABASE_INSTANCES RENAME COLUMN GLOBAL_CODE TO UUID;\\012\\012-- Add constraint DBIN_UUID_UK to the DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_UUID_UK UNIQUE(UUID);\\012\\012-- Drop column in EXPERIMENTS\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012\\012-- Add index to SAMPLES table\\012\\012CREATE INDEX SAMP_CODE_I ON SAMPLES (CODE);\\012\\012-- Bug fix in trigger function SAMPLE_CODE_UNIQUENESS_CHECK()\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:025 ../openbis/source/sql/postgresql/migration/migration-024-025.sql SUCCESS 2008-09-15 14:46:20.011 -- move screenable plates to a group, because it's no longer possible\\012-- to have such plates on the instance level\\012\\012CREATE OR REPLACE FUNCTION move_exp_samples_to_group() RETURNS integer AS $$\\012DECLARE\\012 sample RECORD;\\012 groupId Integer;\\012BEGIN\\012 FOR sample IN \\012 (SELECT * FROM samples s inner join sample_types t on s.saty_id = t.id \\012\\011where t.code in ('CELL_PLATE', 'REINFECT_PLATE'))\\012 LOOP\\012\\011if (sample.dbin_id is not NULL) THEN\\012\\011\\011select proj.grou_id into groupId from\\012\\011\\011\\011samples sa\\012\\011\\011\\011left outer join sample_inputs si on sa.id = si.samp_id \\012\\011\\011\\011left outer join procedures proc on proc.id = si.proc_id \\012\\011\\011\\011left outer join experiments ex on ex.id = proc.expe_id\\012\\011\\011\\011left outer join projects proj on proj.id = ex.proj_id\\012\\011\\011where sa.id = sample.id;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011select id into groupId from groups limit 1;\\012\\011\\011END IF;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011RAISE EXCEPTION 'There is no group in the database - internal error!';\\012\\011\\011END IF;\\012\\011\\011update samples set grou_id = groupId, dbin_id = NULL\\012\\011\\011 where id = sample.id;\\012\\011END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select move_exp_samples_to_group();\\012\\012-- Create new table DATA_STORES.\\012\\012CREATE TABLE DATA_STORES (ID TECH_ID NOT NULL,DBIN_ID TECH_ID NOT NULL,CODE CODE NOT NULL,DOWNLOAD_URL VARCHAR(1024) NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012CREATE SEQUENCE DATA_STORE_ID_SEQ;\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_BK_UK UNIQUE(CODE,DBIN_ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX DAST_DBIN_FK_I ON DATA_STORES (DBIN_ID);\\012\\012-- Add new column DAST_ID (connection to DATA_STORES table) to tables DATABASE_INSTANCES, GROUPS, PROJECTS, EXPERIMENTS.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE GROUPS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE PROJECTS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD COLUMN DAST_ID TECH_ID;\\012\\012-- Create the STANDARD data store and assign it to the home database instance.\\012 \\012insert into data_stores\\012(id\\012,code\\012,download_url\\012,dbin_id)\\012values \\012(nextval('DATA_STORE_ID_SEQ')\\012,'STANDARD'\\012,''\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012update database_instances set dast_id = (select id from data_stores where code = 'STANDARD') where is_original_source = true;\\012\\012-- Add foreign key constratints.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012 \N +./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:026 ../openbis/source/sql/postgresql/migration/migration-025-026.sql SUCCESS 2008-09-15 14:46:20.192 -- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom025To026\\012-- Remove ID column from SAMPLE_INPUTS table\\012DROP SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_sain_pk_constraint() returns void AS $$\\012begin\\012 perform *\\012 FROM information_schema.table_constraints WHERE constraint_name='sain_pk';\\012 if found\\012 then\\012\\011ALTER TABLE SAMPLE_INPUTS DROP CONSTRAINT SAIN_PK;\\012 end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_sain_pk_constraint();\\012drop function remove_sain_pk_constraint();\\012ALTER TABLE SAMPLE_INPUTS DROP COLUMN ID;\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(SAMP_ID,PROC_ID);\\012\\012-- Remove ID column from SAMPLE_MATERIAL_BATCHES table\\012DROP SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_samb_pk_constraint() returns void AS $$\\012begin\\012 perform *\\012 FROM information_schema.table_constraints WHERE constraint_name='SAMB_PK';\\012 if found\\012 then\\012\\012 end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_samb_pk_constraint();\\012drop function remove_samb_pk_constraint();\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES DROP COLUMN ID;\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES ADD CONSTRAINT SAMB_PK PRIMARY KEY(SAMP_ID,MABA_ID);\\012\\012-- Remove ID and REGISTRATION_TIMESTAMP column from DATA_SET_RELATIONSHIPS table\\012DROP SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_PK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_BK_UK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN ID;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN REGISTRATION_TIMESTAMP;\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(DATA_ID_PARENT,DATA_ID_CHILD);\\012\\012-- Rename: \\012-- OBSERVABLE_TYPES -> DATA_SET_TYPES\\012-- OBSERVABLE_TYPE_ID_SEQ -> DATA_SET_TYPE_ID_SEQ\\012-- DATA.OBTY_ID -> DATA.DSTY_ID\\012ALTER TABLE OBSERVABLE_TYPES RENAME TO DATA_SET_TYPES;\\012ALTER TABLE OBSERVABLE_TYPE_ID_SEQ RENAME TO DATA_SET_TYPE_ID_SEQ;\\012ALTER TABLE DATA RENAME COLUMN OBTY_ID TO DSTY_ID;\\012 \N +./sourceTest/sql/postgresql/026/schema-026.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/schema-026.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/schema-026.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/schema-026.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/026/schema-026.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/.svn/text-base/009=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/009=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/027/schema-027.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/schema-027.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/schema-027.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/027/schema-027.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/.svn/text-base/009=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/028/.svn/text-base/009=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/009=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/028/009=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/028/migration/018/experiment-attachments-check/.svn/text-base/buildup.sql.svn-base:$$ LANGUAGE 'plpgsql'; +./sourceTest/sql/postgresql/028/migration/018/experiment-attachments-check/buildup.sql:$$ LANGUAGE 'plpgsql'; +./sourceTest/sql/postgresql/028/schema-028.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/schema-028.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/schema-028.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/028/schema-028.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/.svn/text-base/009=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/029/.svn/text-base/009=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/029/.svn/text-base/009=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/009=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/029/009=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/029/009=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/029/schema-029.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/schema-029.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/schema-029.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/schema-029.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/schema-029.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/schema-029.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/029/schema-029.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/030/schema-030.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/031/schema-031.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/032/schema-032.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/033/schema-033.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/034/schema-034.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/035/schema-035.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/036/schema-036.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/037/schema-037.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/038/schema-038.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/039/schema-039.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/040/schema-040.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/041/schema-041.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/042/schema-042.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/043/schema-043.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/044/schema-044.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.20 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/045/schema-045.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/046/schema-046.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/047/schema-047.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/048/schema-048.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/049/schema-049.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/050/schema-050.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/051/schema-051.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/052/schema-052.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/053/schema-053.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/054/schema-054.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/055/schema-055.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-08 13:44:23.134 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012\\011delete from material_type_property_types where id = \\012\\011\\011(select mtpt.id from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011\\011\\011where pt.id = mtpt.prty_id and mtpt.maty_id = mt.id \\012\\011\\011\\011and pt.code = 'LIBRARY_ID' and mt.code = 'GENE');\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-08 13:44:23.134 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012\\011delete from material_type_property_types where id = \\012\\011\\011(select mtpt.id from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011\\011\\011where pt.id = mtpt.prty_id and mtpt.maty_id = mt.id \\012\\011\\011\\011and pt.code = 'LIBRARY_ID' and mt.code = 'GENE');\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/056/schema-056.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/057/schema-057.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/058/schema-058.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/059/schema-059.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/060/schema-060.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/061/schema-061.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:062 source/sql/postgresql/migration/migration-061-062.sql SUCCESS 2010-11-25 16:02:07.224 \\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_bk_uk,\\012 ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_dbin_fk,\\012 ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_pers_fk_registerer,\\012 ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012 \N +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:062 source/sql/postgresql/migration/migration-061-062.sql SUCCESS 2010-11-25 16:02:07.224 \\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_bk_uk,\\012 ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_dbin_fk,\\012 ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_pers_fk_registerer,\\012 ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012 \N +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/062/schema-062.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:062 source/sql/postgresql/migration/migration-061-062.sql SUCCESS 2010-11-25 16:02:07.224 \\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_bk_uk,\\012 ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_dbin_fk,\\012 ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_pers_fk_registerer,\\012 ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012 \N +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:062 source/sql/postgresql/migration/migration-061-062.sql SUCCESS 2010-11-25 16:02:07.224 \\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_bk_uk,\\012 ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_dbin_fk,\\012 ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_pers_fk_registerer,\\012 ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012 \N +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/063/schema-063.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:062 source/sql/postgresql/migration/migration-061-062.sql SUCCESS 2010-11-25 16:02:07.224 \\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_bk_uk,\\012 ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_dbin_fk,\\012 ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_pers_fk_registerer,\\012 ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012 \N +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:027 D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql SUCCESS 2008-11-05 09:18:00.403 -- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:028 source/sql/postgresql/migration/migration-027-028.sql SUCCESS 2008-11-18 13:24:17.508 -- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 seq BIGINT;\\012BEGIN\\012 FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012 \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012 INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012 UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:029 source/sql/postgresql/migration/migration-028-029.sql SUCCESS 2009-03-18 10:50:20.105 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012-- It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012 FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012 FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012 \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:030 source/sql/postgresql/migration/migration-029-030.sql SUCCESS 2009-03-23 15:34:44.72 -- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_type_id CODE;\\012 v_type_id_prop CODE;\\012BEGIN\\012 if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011 from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011 from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012 FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK(); \\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:032 source/sql/postgresql/migration/migration-031-032.sql SUCCESS 2009-04-09 09:36:36.2 -- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012 DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012 ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012 WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012 WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012 ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012 DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012 ADD COLUMN remote_url character varying(250),\\012 ADD COLUMN session_token character varying(50),\\012 ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012 ALTER COLUMN remote_url SET NOT NULL,\\012 ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012 DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012 DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012 ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012 ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012 ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 IF (NEW.samp_id_part_of is NULL) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 ELSE\\012 IF (NEW.dbin_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 ELSIF (NEW.grou_id is not NULL) THEN\\012 SELECT count(*) into counter FROM samples \\012 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012 IF (counter > 0) THEN\\012 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012 END IF;\\012 END IF;\\012 END IF; \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:034 source/sql/postgresql/migration/migration-033-034.sql SUCCESS 2009-05-26 08:32:49.935 ------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012 RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012 ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012 ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012 SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012 SET samp_id = samp_id_derived_from \\012 WHERE is_derived = 'TRUE';\\012UPDATE data\\012 SET samp_id = samp_id_acquired_from \\012 WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012 ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012 ALTER COLUMN samp_id SET NOT NULL; \\012ALTER TABLE data\\012 ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012 DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012 DROP COLUMN samp_id_derived_from;\\012 \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:041 source/sql/postgresql/migration/migration-040-041.sql SUCCESS 2009-09-14 13:48:57.539 -- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012 SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012-- SELECT r.data_id_child AS id, \\012-- ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012-- false AS cycle \\012-- FROM data_set_relationships r\\012-- UNION ALL\\012-- SELECT r.data_id_child,\\012-- CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012-- r.data_id_child = ANY(p.parent_ids)\\012-- FROM data_set_relationships r, data_set_parents p\\012-- WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Create DEFERRED triggers:\\012-- * check_dataset_relationships_on_data_table_modification,\\012-- * check_dataset_relationships_on_relationships_table_modification.\\012-- They check that after all modifications of database (just before commit) \\012-- if 'data'/'data_set_relationships' tables are among modified tables \\012-- dataset is not connected with a sample and a parent dataset at the same time.\\012-- This connections are held in two different tables so simple immediate trigger \\012-- with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012 AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012 AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:053 source/sql/postgresql/migration/migration-052-053.sql SUCCESS 2010-06-08 15:27:55.032 -- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012 FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012 \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:054 source/sql/postgresql/migration/migration-053-054.sql SUCCESS 2010-07-27 11:30:46.766 -- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011 id,\\012\\011 saty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if; \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:056 source/sql/postgresql/migration/migration-055-056.sql SUCCESS 2010-09-10 09:06:20.278 -- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012 BEGIN\\012 IF character_length($1) > 0 THEN\\012 RETURN $1 || ' ' || $2;\\012 ELSE\\012 RETURN $2;\\012 END IF;\\012 END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012 SFUNC = merge_words,\\012 STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011 id,\\012\\011 maty_id,\\012\\011 prty_id,\\012\\011 is_mandatory,\\012\\011 pers_id_registerer,\\012\\011 ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011 , mate_id\\012\\011 , mtpt_id\\012\\011 , "value"\\012\\011 , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011 \\011, genes.id mate_id\\012\\011 , (select mtpt.id\\012\\011 \\011\\011from material_type_property_types mtpt, material_types mt, property_types pt\\012\\011 \\011\\011where pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011 \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011 , genes.gene_codes "value"\\012\\011 , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:059 source/sql/postgresql/migration/migration-058-059.sql SUCCESS 2010-09-29 13:37:07.231 -- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger that checks if entity_type_code specified in a query\\012-- matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 if (NEW.entity_type_code IS NOT NULL) then\\012 if (NEW.query_type = 'GENERIC') then\\012 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012 elsif (NEW.query_type = 'EXPERIMENT') then\\012 SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012 SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012 SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012 SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012 end if;\\012 RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012 FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012 \N +./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:062 source/sql/postgresql/migration/migration-061-062.sql SUCCESS 2010-11-25 16:02:07.224 \\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012\\011 IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012 END IF;\\012 ELSE\\012\\011\\011 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011 SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011 where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011 IF (counter > 0) THEN\\012\\011\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011 END IF;\\012\\011\\011 END IF;\\012 END IF; \\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012 LANGUAGE plpgsql\\012 AS $$\\012DECLARE\\012 counter INTEGER;\\012 unique_subcode BOOLEAN_CHAR;\\012BEGIN\\012 LOCK TABLE samples IN EXCLUSIVE MODE;\\012 \\012 SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012 \\012 IF (unique_subcode) THEN\\012 IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012 END IF;\\012 \\012 RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_bk_uk,\\012 ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_dbin_fk,\\012 ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012 DROP CONSTRAINT grou_pers_fk_registerer,\\012 ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012 \N +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/064/schema-064.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/065/schema-065.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/066/schema-066.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/067/schema-067.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/068/schema-068.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/069/schema-069.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/070/schema-070.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/071/schema-071.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/072/schema-072.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/073/schema-073.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/074/schema-074.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/075/schema-075.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/076/schema-076.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/077/schema-077.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/078/schema-078.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/079/schema-079.sql: LANGUAGE plpgsql +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/.svn/text-base/003=database_version_logs.tsv.svn-base:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2007-12-04 15:50:54.064 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/.svn/text-base/schema-007.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/003=database_version_logs.tsv:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2007-12-04 15:50:54.064 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/schema-007.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2007-12-04 15:50:54.064 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:013 source/sql/postgresql/migration/migration-012-013.sql SUCCESS 2008-08-29 08:10:55.399 ----------------------------------------------------------------------------------------------\\012-- File: migration-012-013.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 012 to 013.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table SAMPLES in order to allow invalidation of samples \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type BACTERIUM\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'BACTERIUM')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012 -----------------------\\012 -- Material Type COMPOUND\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'COMPOUND')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:014 source/sql/postgresql/migration/migration-013-014.sql SUCCESS 2008-08-29 08:10:55.582 ----------------------------------------------------------------------------------------------\\012-- File: migration-013-014.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 013 to 014.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012-- the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012-- Purpose: Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column COVO_ID to table PROPERTY_TYPES \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 cnt INTEGER;\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Insert into the table DATA_TYPES\\012--\\012-- Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012-- Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012-- to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012-- This results in having all CONTROL_LAYOUTs being directly linked \\012-- to CELL_PLATEs. \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012 SET samp_id_control_layout = \\012 (select control_layout.samp_id\\012 from sample_inputs control_layout inner join samples s \\012 on control_layout.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 and proc_id = (\\012 select proc_id\\012 from sample_inputs cp\\012 where cp.samp_id = cell_plate.id))\\012 WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012 and id = (select distinct (samp_id)\\012 from sample_inputs sain inner join samples s2 \\012 on sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012-- Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where id in (select si.id \\012 from sample_inputs si inner join samples s \\012 on si.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 )\\012;\\012\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:016 source/sql/postgresql/migration/migration-015-016.sql SUCCESS 2008-08-29 08:11:12.328 ----------------------------------------------------------------------------------------------\\012-- File: migration-015-016.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 015 to 016.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012-- and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012-- This adds time zone information and allows for a clean separation between registration time stamps\\012-- which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012-- to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012BEGIN\\012 FOR rec IN SELECT * FROM data LOOP\\012 rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012 update data set code=rec.code where id=rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != '.STORAGE_FORMAT' then\\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012 ( id\\012 , code\\012 , description\\012 , pers_id_registerer\\012 , is_managed_internally )\\012values (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012 , '.STORAGE_FORMAT'\\012 , 'The on-disk storage format of a data set'\\012 , (select id from persons where user_id ='system')\\012 , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'PROPRIETARY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'BDS_DIRECTORY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012-- Purpose: Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012-- Purpose: Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012 dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012 select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012 where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012 update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 meas_ts TIMESTAMP;\\012 ds_code CODE;\\012 meas_ts_str TEXT;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code; \\012 FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012 meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012 ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012 IF meas_ts_str is not null and ds_code is not null THEN\\012 meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012 update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012 END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012 IF ts1 < ts2 THEN\\012 RETURN ts2 - ts1;\\012 ELSE\\012 RETURN ts1 - ts2;\\012 END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012 source_id TECH_ID;\\012 rec_derived RECORD;\\012 rec_acquired RECORD;\\012 rel_location TEXT;\\012 data_set_code TEXT;\\012 data_set_code_trial TEXT;\\012 loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 count INTEGER := 0;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code;\\012 FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012 source_id := NULL;\\012 select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012 IF rel_location is not null then\\012 data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code is not null THEN\\012 FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012 select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012 IF rel_location is not null THEN\\012 data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code_trial = data_set_code THEN\\012 source_id = rec_acquired.id;\\012 EXIT;\\012 END IF;\\012 END IF;\\012 END LOOP;\\012 END IF;\\012 END IF;\\012 -- If the location didn't tell us about data set relationships, try the backup strategy.\\012 IF source_id is null THEN\\012 -- Use the measured data set as source that is closest in registration timestamp.\\012 select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012 and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012 = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012 from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012 END IF;\\012 IF source_id is not null THEN\\012 insert into data_set_relationships (id, data_id_parent, data_id_child)\\012 values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012 count := count + 1;\\012 END IF;\\012 END LOOP;\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012-- properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 cnt INTEGER := 0;\\012 already_exists INTEGER;\\012 new_label TEXT;\\012 this_id TECH_ID;\\012BEGIN\\012 FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012 IF this_key = prev_key THEN\\012 dup_count := dup_count + 1;\\012 cnt := cnt + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_label := this_key || '(' || dup_count::text || ')';\\012 select count(*) into already_exists from property_types where label = new_label;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 update property_types set label = new_label where id = this_id;\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '96_WELLS_8X12'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '1536_WELLS_32X48'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012-- and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012-- and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012 where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012 or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012 || ' order by upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key);\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 prev_key2 TECH_ID;\\012 this_key TEXT;\\012 this_key2 TECH_ID;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012 || ' order by ' || clm2 || ',upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012 || clm2 || ' = ' || quote_literal(this_key2);\\012 END IF;\\012 prev_key := this_key;\\012 prev_key2 := this_key2;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Delete sample_components with no associated material_batches.\\012-- This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where id in (select sc.id \\012 from sample_components as sc left join sample_component_materials as scm \\012 on scm.saco_id = sc.id \\012 where scm.saco_id is null\\012 )\\012;\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:017 source/sql/postgresql/migration/migration-016-017.sql SUCCESS 2008-08-29 08:11:12.644 ----------------------------------------------------------------------------------------------\\012-- File: migration-016-017.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 016 to 017.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011 When\\011\\011 What\\012--\\011---\\011\\011\\011 ---- \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012-- Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012-- CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type SIRNHACS\\012 -----------------------\\012\\012insert into experiment_type_property_types\\012( id\\012 ,exty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,is_managed_internally\\012 ,pers_id_registerer\\012 )\\012values \\012( nextval('ETPT_ID_SEQ')\\012 ,(select id from experiment_types where code = 'SIRNAHCS')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012( id\\012 ,expe_id\\012 ,value\\012 ,etpt_id\\012 ,pers_id_registerer\\012)\\012select\\012 nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012 ,id\\012 ,case when description is not null then description else 'No description given' end\\012 ,currval('ETPT_ID_SEQ')\\012 ,(select id from persons where user_id ='system') \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/schema-018.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/schema-018.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/schema-018.sql.svn-base: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:007 source/sql/postgresql/007/schema-007.sql SUCCESS 2007-12-04 15:50:54.064 -- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23 19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012-- 1. change domain FILE from BIT(32000) to BYTEA\\012-- 2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012-- 3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012-- i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012-- 4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012-- Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012-- Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012-- Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012 Trigger Section\\012 ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012 cnt INTEGER;\\012 v_cell_plate CODE;\\012BEGIN\\012\\012 select code into v_cell_plate from sample_types where id = NEW.saty_id;\\012\\012 -- Check if the sample is of type "Cell Plate"\\012 if v_cell_plate = 'CELL PLATE' then\\012\\012 -- Check that a Control Plate exists before registering the Cell Plate\\012 select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012 IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012 -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012 END IF;\\012\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012 FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:013 source/sql/postgresql/migration/migration-012-013.sql SUCCESS 2008-08-29 08:10:55.399 ----------------------------------------------------------------------------------------------\\012-- File: migration-012-013.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 012 to 013.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012 CURR_SEQ_VAL INTEGER;\\012BEGIN\\012 SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012 EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012 EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012 RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table SAMPLES in order to allow invalidation of samples \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type BACTERIUM\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'BACTERIUM')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012 -----------------------\\012 -- Material Type COMPOUND\\012 -----------------------\\012\\012insert into material_type_property_types\\012( id\\012 ,maty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,pers_id_registerer\\012 )\\012values \\012 (nextval('MTPT_ID_SEQ')\\012 ,(select id from material_types where code = 'COMPOUND')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:014 source/sql/postgresql/migration/migration-013-014.sql SUCCESS 2008-08-29 08:10:55.582 ----------------------------------------------------------------------------------------------\\012-- File: migration-013-014.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 013 to 014.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012-- the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012-- Purpose: Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012-- Purpose: Add column COVO_ID to table PROPERTY_TYPES \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 cnt INTEGER;\\012 v_code CODE;\\012BEGIN\\012\\012 select code into v_code from data_types where id = NEW.daty_id;\\012\\012 -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012 if v_code = 'CONTROLLEDVOCABULARY' then\\012 if NEW.covo_id IS NULL then\\012 RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012 end if;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012 FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Insert into the table DATA_TYPES\\012--\\012-- Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012-- Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012-- to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012-- This results in having all CONTROL_LAYOUTs being directly linked \\012-- to CELL_PLATEs. \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012 SET samp_id_control_layout = \\012 (select control_layout.samp_id\\012 from sample_inputs control_layout inner join samples s \\012 on control_layout.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 and proc_id = (\\012 select proc_id\\012 from sample_inputs cp\\012 where cp.samp_id = cell_plate.id))\\012 WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012 and id = (select distinct (samp_id)\\012 from sample_inputs sain inner join samples s2 \\012 on sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012-- Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where id in (select si.id \\012 from sample_inputs si inner join samples s \\012 on si.samp_id = s.id\\012 where s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012 )\\012;\\012\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:016 source/sql/postgresql/migration/migration-015-016.sql SUCCESS 2008-08-29 08:11:12.328 ----------------------------------------------------------------------------------------------\\012-- File: migration-015-016.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 015 to 016.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012-- and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012-- This adds time zone information and allows for a clean separation between registration time stamps\\012-- which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012-- to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012BEGIN\\012 FOR rec IN SELECT * FROM data LOOP\\012 rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012 update data set code=rec.code where id=rec.id;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012 -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != '.STORAGE_FORMAT' then\\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012 FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012 ( id\\012 , code\\012 , description\\012 , pers_id_registerer\\012 , is_managed_internally )\\012values (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012 , '.STORAGE_FORMAT'\\012 , 'The on-disk storage format of a data set'\\012 , (select id from persons where user_id ='system')\\012 , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'PROPRIETARY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer )\\012values (nextval('CVTE_ID_SEQ')\\012 , 'BDS_DIRECTORY'\\012 , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012 , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012-- Purpose: Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012-- Purpose: Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012 dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012 select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012 where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012 update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012 rec RECORD;\\012 loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 meas_ts TIMESTAMP;\\012 ds_code CODE;\\012 meas_ts_str TEXT;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code; \\012 FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012 meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012 ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012 IF meas_ts_str is not null and ds_code is not null THEN\\012 meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012 update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012 END IF;\\012 END LOOP;\\012 RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012 IF ts1 < ts2 THEN\\012 RETURN ts2 - ts1;\\012 ELSE\\012 RETURN ts1 - ts2;\\012 END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012 source_id TECH_ID;\\012 rec_derived RECORD;\\012 rec_acquired RECORD;\\012 rel_location TEXT;\\012 data_set_code TEXT;\\012 data_set_code_trial TEXT;\\012 loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012 loty_rel_id TECH_ID;\\012 count INTEGER := 0;\\012BEGIN\\012 select id into loty_rel_id from locator_types where code = loty_rel_code;\\012 FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012 source_id := NULL;\\012 select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012 IF rel_location is not null then\\012 data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code is not null THEN\\012 FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012 select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012 IF rel_location is not null THEN\\012 data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012 IF data_set_code_trial = data_set_code THEN\\012 source_id = rec_acquired.id;\\012 EXIT;\\012 END IF;\\012 END IF;\\012 END LOOP;\\012 END IF;\\012 END IF;\\012 -- If the location didn't tell us about data set relationships, try the backup strategy.\\012 IF source_id is null THEN\\012 -- Use the measured data set as source that is closest in registration timestamp.\\012 select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012 and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012 = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012 from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012 END IF;\\012 IF source_id is not null THEN\\012 insert into data_set_relationships (id, data_id_parent, data_id_child)\\012 values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012 count := count + 1;\\012 END IF;\\012 END LOOP;\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012-- properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012-- Purpose: Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 cnt INTEGER := 0;\\012 already_exists INTEGER;\\012 new_label TEXT;\\012 this_id TECH_ID;\\012BEGIN\\012 FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012 IF this_key = prev_key THEN\\012 dup_count := dup_count + 1;\\012 cnt := cnt + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_label := this_key || '(' || dup_count::text || ')';\\012 select count(*) into already_exists from property_types where label = new_label;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 update property_types set label = new_label where id = this_id;\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '96_WELLS_8X12'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012 ( id\\012 , code\\012 , covo_id \\012 , pers_id_registerer)\\012values (nextval('CVTE_ID_SEQ')\\012 , '1536_WELLS_32X48'\\012 , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012 , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012-- and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012-- and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012 where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012 or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 this_key TEXT;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012 || ' order by upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key);\\012 END IF;\\012 prev_key := this_key;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012 prev_key TEXT := NULL;\\012 prev_key2 TECH_ID;\\012 this_key TEXT;\\012 this_key2 TECH_ID;\\012 dup_count INTEGER;\\012 count INTEGER := 0;\\012 already_exists INTEGER;\\012 new_clm TEXT;\\012BEGIN\\012 FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012 || ' order by ' || clm2 || ',upper(' || clm || '),id' LOOP\\012 IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012 dup_count := dup_count + 1;\\012 count := count + 1;\\012 ELSE\\012 dup_count := 0;\\012 END IF;\\012 IF dup_count > 0 THEN\\012 -- Check whether the new key already exists.\\012 LOOP\\012 new_clm := this_key || '(' || dup_count::text || ')';\\012 EXECUTE 'select count(*) from ' || tbl \\012 || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012 || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012 into already_exists;\\012 IF already_exists = 0 THEN\\012 EXIT;\\012 END IF;\\012 dup_count := dup_count + 1;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012 ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012 || clm2 || ' = ' || quote_literal(this_key2);\\012 END IF;\\012 prev_key := this_key;\\012 prev_key2 := this_key2;\\012 END LOOP;\\012 EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012 RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012-- Purpose: Delete sample_components with no associated material_batches.\\012-- This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where id in (select sc.id \\012 from sample_components as sc left join sample_component_materials as scm \\012 on scm.saco_id = sc.id \\012 where scm.saco_id is null\\012 )\\012;\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:017 source/sql/postgresql/migration/migration-016-017.sql SUCCESS 2008-08-29 08:11:12.644 ----------------------------------------------------------------------------------------------\\012-- File: migration-016-017.sql\\012--\\012-- \\012-- This script enables the migration of the database schema from 016 to 017.\\012-- \\012-- Update History\\012--\\012--\\012--\\011Who\\011\\011\\011 When\\011\\011 What\\012--\\011---\\011\\011\\011 ---- \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012-- \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012 v_covo_code CODE;\\012 data_code CODE;\\012BEGIN\\012\\012 select code into v_covo_code from controlled_vocabularies\\012 where is_internal_namespace = true and \\012 id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012 if v_covo_code != 'STORAGE_FORMAT' then\\012 select code into data_code from data where id = NEW.data_id; \\012 RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012 end if;\\012\\012 RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012-- Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012-- CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET code = substr(code,2,length(code))\\012 , is_internal_namespace = true \\012WHERE substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012-- Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012 -----------------------\\012 -- Material Type SIRNHACS\\012 -----------------------\\012\\012insert into experiment_type_property_types\\012( id\\012 ,exty_id\\012 ,prty_id\\012 ,is_mandatory\\012 ,is_managed_internally\\012 ,pers_id_registerer\\012 )\\012values \\012( nextval('ETPT_ID_SEQ')\\012 ,(select id from experiment_types where code = 'SIRNAHCS')\\012 ,(select id from property_types where code = 'DESCRIPTION')\\012 ,true\\012 ,true\\012 ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012( id\\012 ,expe_id\\012 ,value\\012 ,etpt_id\\012 ,pers_id_registerer\\012)\\012select\\012 nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012 ,id\\012 ,case when description is not null then description else 'No description given' end\\012 ,currval('ETPT_ID_SEQ')\\012 ,(select id from persons where user_id ='system') \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012 \N +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/schema-018.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/schema-018.sql: LANGUAGE plpgsql; +./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/schema-018.sql: LANGUAGE plpgsql; +Binary file ./targets/ant/classes/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.class matches +./targets/dump.sql:-- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: - +./targets/dump.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/dump.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql:-- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: - +./targets/unit-test-wd/currentDatabaseSchema.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/currentDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql:-- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: - +./targets/unit-test-wd/migratedDatabaseSchema.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +./targets/unit-test-wd/migratedDatabaseSchema.sql: LANGUAGE plpgsql +Binary file ./targets/www/WEB-INF/classes/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.class matches +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html: LANGUAGE plpgsql +./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.html:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml: LANGUAGE plpgsql +./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/Db/Db.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p> +./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p> +./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p> +./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p> +./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p> +./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p> +./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html: LANGUAGE plpgsql +./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p> +./test-output/emailable-report.html:<p>Caused by ERROR: must be owner of language plpgsql</p> +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml: LANGUAGE plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql; +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml: LANGUAGE plpgsql +./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql +./test-output/testng-results.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java index 4fd83c4b8f5c6cfc45a4d5e02225266f3b36661a..8ce9d8033ffee2394e40bd8aafe374e93f2da38f 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java @@ -90,14 +90,33 @@ public class ExcelFileSection } } - public static List<ExcelFileSection> extractSections(InputStream stream) + public static List<ExcelFileSection> extractSections(InputStream stream, String excelSheetName) { List<ExcelFileSection> sections = new ArrayList<ExcelFileSection>(); try { POIFSFileSystem poifsFileSystem = new POIFSFileSystem(stream); Workbook wb = new HSSFWorkbook(poifsFileSystem); - Sheet sheet = wb.getSheetAt(0); + + Sheet sheet = null; + if (excelSheetName == null) + { + sheet = wb.getSheetAt(0); + } else + { + for (int i = 0; i < wb.getNumberOfSheets(); i++) + { + if (excelSheetName.equalsIgnoreCase(wb.getSheetName(i))) + { + sheet = wb.getSheetAt(i); + break; + } + } + if (sheet == null) + { + return sections; + } + } String sectionName = null; Integer begin = null; for (Row row : sheet) diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java index a7ca423d9e4002201e3bb28b44666f4847a808c6..0e4c2c8c9672cf61bd6ccaf8eab1ded116fda1be 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java @@ -86,13 +86,13 @@ public class SampleUploadSectionsParser public static BatchSamplesOperation prepareSamples(final SampleType sampleType, final Collection<NamedInputStream> files, String defaultGroupIdentifier, final SampleCodeGenerator sampleCodeGeneratorOrNull, final boolean allowExperiments, - BatchOperationKind operationKind) + String excelSheetName, BatchOperationKind operationKind) { final List<NewSamplesWithTypes> newSamples = new ArrayList<NewSamplesWithTypes>(); boolean isAutoGenerateCodes = (sampleCodeGeneratorOrNull != null); final List<BatchRegistrationResult> results = loadSamplesFromFiles(files, sampleType, isAutoGenerateCodes, newSamples, - allowExperiments, operationKind); + allowExperiments, excelSheetName, operationKind); if (defaultGroupIdentifier != null) { @@ -185,7 +185,7 @@ public class SampleUploadSectionsParser private static List<BatchRegistrationResult> loadSamplesFromFiles( Collection<NamedInputStream> uploadedFiles, SampleType sampleType, boolean isAutoGenerateCodes, final List<NewSamplesWithTypes> newSamples, - boolean allowExperiments, BatchOperationKind operationKind) + boolean allowExperiments, String excelSheetName, BatchOperationKind operationKind) { final List<BatchRegistrationResult> results = new ArrayList<BatchRegistrationResult>(uploadedFiles.size()); @@ -196,8 +196,8 @@ public class SampleUploadSectionsParser List<ExcelFileSection> sampleSections = new ArrayList<ExcelFileSection>(); if (sampleType.isDefinedInFileEntityTypeCode()) { - sampleSections.addAll(ExcelFileSection.extractSections(multipartFile - .getInputStream())); + sampleSections.addAll(ExcelFileSection.extractSections( + multipartFile.getInputStream(), excelSheetName)); } else { sampleSections.add(ExcelFileSection.createFromInputStream( diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java index 4a6960dfc61b8067d10b41046a5771be8883d9b5..2d0774bafe83f31e2f35a53e6e12617ffb7d6bd4 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java @@ -173,4 +173,11 @@ public interface IGenericClientService extends IClientService */ public List<BatchRegistrationResult> updateDataSets(final DataSetType dataSetType, final String sessionKey) throws UserFailureException; + + /** + * Updates samples and materials from excel files which have been previously uploaded. + */ + public List<BatchRegistrationResult> registerOrUpdateSamplesAndMaterials( + final String sessionKey, final String defaultGroupIdentifier, boolean updateExisting); + } diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java index 4382a23d55a7d7e7783cb2c160e81f374635721d..f2ddcb45d7b0717d611bf5fd1e6632fee76892ee 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java @@ -150,4 +150,11 @@ public interface IGenericClientServiceAsync extends IClientServiceAsync public void registerExperiments(ExperimentType experimentType, String sessionKey, AsyncCallback<List<BatchRegistrationResult>> registerExperimentsCallback); + /** + * @see IGenericClientService#registerOrUpdateSamplesAndMaterials(String, String, boolean) + */ + public void registerOrUpdateSamplesAndMaterials(final String sessionKey, + final String defaultGroupIdentifier, boolean updateExisting, + AsyncCallback<List<BatchRegistrationResult>> registerSamplesAndMaterialsCallback); + } diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java index bec666c423905f0dcc361452892e9f35aa83fd6b..f211c0a6e33452b1c24ebaa2923d7e64c8887260 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java @@ -159,7 +159,7 @@ public class GenericClientService extends AbstractClientService implements IGene updateExisting ? BatchOperationKind.UPDATE : BatchOperationKind.REGISTRATION; BatchSamplesOperation info = parseSamples(sampleType, sessionKey, defaultGroupIdentifier, - defaultGroupIdentifier != null, true, operationKind); + defaultGroupIdentifier != null, true, null, operationKind); try { final String sessionToken = getSessionToken(); @@ -171,11 +171,51 @@ public class GenericClientService extends AbstractClientService implements IGene } } + public final List<BatchRegistrationResult> registerOrUpdateSamplesAndMaterials( + final String sessionKey, final String defaultGroupIdentifier, boolean updateExisting) + { + BatchOperationKind operationKind = + updateExisting ? BatchOperationKind.UPDATE : BatchOperationKind.REGISTRATION; + + final SampleType sampleType = new SampleType(); + sampleType.setCode(SampleType.DEFINED_IN_FILE); + + HttpSession session = getHttpSession(); + UploadedFilesBean uploadedFiles = null; + try + { + uploadedFiles = getUploadedFiles(sessionKey, session); + BatchSamplesOperation samplesInfo = + parseSamples(sampleType, session, uploadedFiles, defaultGroupIdentifier, + defaultGroupIdentifier != null, true, "SAMPLES", operationKind); + + final MaterialType materialType = new MaterialType(); + materialType.setCode(SampleType.DEFINED_IN_FILE); + BatchMaterialsOperation materialsInfo = + parseMaterials(session, uploadedFiles, materialType, "MATERIALS", + updateExisting); + final String sessionToken = getSessionToken(); + genericServer.registerOrUpdateSamplesAndMaterials(sessionToken, + samplesInfo.getSamples(), materialsInfo.getMaterials()); + + List<BatchRegistrationResult> results = new ArrayList<BatchRegistrationResult>(); + results.addAll(materialsInfo.getResultList()); + results.addAll(samplesInfo.getResultList()); + return results; + } catch (final ch.systemsx.cisd.common.exceptions.UserFailureException e) + { + throw UserFailureExceptionTranslator.translate(e); + } finally + { + cleanUploadedFiles(sessionKey, session, uploadedFiles); + } + } + public final List<BatchRegistrationResult> updateSamples(final SampleType sampleType, final String sessionKey, final String defaultGroupIdentifier) { BatchSamplesOperation info = - parseSamples(sampleType, sessionKey, defaultGroupIdentifier, false, true, + parseSamples(sampleType, sessionKey, defaultGroupIdentifier, false, true, null, BatchOperationKind.UPDATE); try { @@ -217,7 +257,7 @@ public class GenericClientService extends AbstractClientService implements IGene samplesSessionKey, new GroupIdentifier(identifier.getDatabaseInstanceCode(), identifier .getSpaceCode()).toString(), experiment.isGenerateCodes(), - false, BatchOperationKind.REGISTRATION); + false, null, BatchOperationKind.REGISTRATION); experiment.setNewSamples(result.getSamples()); experiment.setSamples(result.getCodes()); } @@ -231,31 +271,40 @@ public class GenericClientService extends AbstractClientService implements IGene }.process(attachmentsSessionKey, getHttpSession(), experiment.getAttachments()); } + private BatchSamplesOperation parseSamples(final SampleType sampleType, + HttpSession httpSession, UploadedFilesBean uploadedFiles, + String defaultGroupIdentifier, final boolean isAutoGenerateCodes, + final boolean allowExperiments, String excelSheetName, BatchOperationKind operationKind) + { + boolean updateExisting = (operationKind == BatchOperationKind.UPDATE); + SampleCodeGenerator sampleCodeGeneratorOrNull = + tryGetSampleCodeGenerator(isAutoGenerateCodes); + Collection<NamedInputStream> files = new ArrayList<NamedInputStream>(uploadedFiles.size()); + for (IUncheckedMultipartFile f : uploadedFiles.iterable()) + { + files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename())); + } + BatchSamplesOperation batchSamplesOperation = + SampleUploadSectionsParser.prepareSamples(sampleType, files, + defaultGroupIdentifier, sampleCodeGeneratorOrNull, allowExperiments, + excelSheetName, operationKind); + setUpdatePossibility(batchSamplesOperation.getSamples(), updateExisting); + return batchSamplesOperation; + + } + private BatchSamplesOperation parseSamples(final SampleType sampleType, final String sessionKey, String defaultGroupIdentifier, final boolean isAutoGenerateCodes, final boolean allowExperiments, - BatchOperationKind operationKind) + String excelSheetName, BatchOperationKind operationKind) { HttpSession httpSession = getHttpSession(); UploadedFilesBean uploadedFiles = null; - boolean updateExisting = (operationKind == BatchOperationKind.UPDATE); try { - SampleCodeGenerator sampleCodeGeneratorOrNull = - tryGetSampleCodeGenerator(isAutoGenerateCodes); uploadedFiles = getUploadedFiles(sessionKey, httpSession); - Collection<NamedInputStream> files = - new ArrayList<NamedInputStream>(uploadedFiles.size()); - for (IUncheckedMultipartFile f : uploadedFiles.iterable()) - { - files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename())); - } - BatchSamplesOperation batchSamplesOperation = - SampleUploadSectionsParser.prepareSamples(sampleType, files, - defaultGroupIdentifier, sampleCodeGeneratorOrNull, allowExperiments, - operationKind); - setUpdatePossibility(batchSamplesOperation.getSamples(), updateExisting); - return batchSamplesOperation; + return parseSamples(sampleType, httpSession, uploadedFiles, defaultGroupIdentifier, + isAutoGenerateCodes, allowExperiments, excelSheetName, operationKind); } finally { cleanUploadedFiles(sessionKey, httpSession, uploadedFiles); @@ -292,7 +341,8 @@ public class GenericClientService extends AbstractClientService implements IGene boolean updateExisting, final String sessionKey) { String sessionToken = getSessionToken(); - BatchMaterialsOperation results = parseMaterials(sessionKey, materialType, updateExisting); + BatchMaterialsOperation results = + parseMaterials(sessionKey, materialType, null, updateExisting); List<NewMaterialsWithTypes> materials = results.getMaterials(); genericServer.registerOrUpdateMaterials(sessionToken, materials); return results.getResultList(); @@ -315,7 +365,7 @@ public class GenericClientService extends AbstractClientService implements IGene { String sessionToken = getSessionToken(); - BatchMaterialsOperation results = parseMaterials(sessionKey, materialType, true); + BatchMaterialsOperation results = parseMaterials(sessionKey, materialType, null, true); int updateCount = genericServer.updateMaterials(sessionToken, results.getMaterials(), ignoreUnregisteredMaterials); @@ -364,25 +414,33 @@ public class GenericClientService extends AbstractClientService implements IGene } } - private BatchMaterialsOperation parseMaterials(String sessionKey, MaterialType materialType, + private BatchMaterialsOperation parseMaterials(HttpSession session, + UploadedFilesBean uploadedFiles, MaterialType materialType, String excelSheetName, boolean updateExisting) + { + Collection<NamedInputStream> files = new ArrayList<NamedInputStream>(uploadedFiles.size()); + for (IUncheckedMultipartFile f : uploadedFiles.iterable()) + { + files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename())); + } + + BatchMaterialsOperation batchMaterialsOperation = + MaterialUploadSectionsParser.prepareMaterials(materialType, files, excelSheetName); + setUpdatePossibility(batchMaterialsOperation.getMaterials(), updateExisting); + return batchMaterialsOperation; + } + + private BatchMaterialsOperation parseMaterials(String sessionKey, MaterialType materialType, + String excelSheetName, boolean updateExisting) { HttpSession session = getHttpSession(); UploadedFilesBean uploadedFiles = null; try { uploadedFiles = getUploadedFiles(sessionKey, session); - Collection<NamedInputStream> files = - new ArrayList<NamedInputStream>(uploadedFiles.size()); - for (IUncheckedMultipartFile f : uploadedFiles.iterable()) - { - files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename())); - } - BatchMaterialsOperation batchMaterialsOperation = - MaterialUploadSectionsParser.prepareMaterials(materialType, files); - setUpdatePossibility(batchMaterialsOperation.getMaterials(), updateExisting); - return batchMaterialsOperation; + return parseMaterials(session, uploadedFiles, materialType, excelSheetName, + updateExisting); } finally { cleanUploadedFiles(sessionKey, session, uploadedFiles); @@ -453,7 +511,7 @@ public class GenericClientService extends AbstractClientService implements IGene updates.getSamplesSessionKey(), new GroupIdentifier(newProject.getDatabaseInstanceCode(), newProject .getSpaceCode()).toString(), updates.isGenerateCodes(), false, - BatchOperationKind.REGISTRATION); + null, BatchOperationKind.REGISTRATION); updates.setNewSamples(info.getSamples()); updates.setSampleCodes(info.getCodes()); } diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java index 678bdbd2152b2e332ab5201cf0215e3ee2e5e684..427de31285332bd7d956cd4fdf17c65865615192 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java @@ -78,11 +78,11 @@ public class MaterialUploadSectionsParser } public static BatchMaterialsOperation prepareMaterials(final MaterialType materialType, - final Collection<NamedInputStream> files) + final Collection<NamedInputStream> files, String excelSheetName) { final List<NewMaterialsWithTypes> newSamples = new ArrayList<NewMaterialsWithTypes>(); final List<BatchRegistrationResult> results = - loadMaterialsFromFiles(files, materialType, newSamples); + loadMaterialsFromFiles(files, materialType, newSamples, excelSheetName); return new BatchMaterialsOperation(newSamples, results, parseCodes(newSamples)); } @@ -102,7 +102,7 @@ public class MaterialUploadSectionsParser private static List<BatchRegistrationResult> loadMaterialsFromFiles( Collection<NamedInputStream> uploadedFiles, MaterialType materialType, - final List<NewMaterialsWithTypes> newMaterials) + final List<NewMaterialsWithTypes> newMaterials, String excelSheetName) { final List<BatchRegistrationResult> results = new ArrayList<BatchRegistrationResult>(uploadedFiles.size()); @@ -113,8 +113,8 @@ public class MaterialUploadSectionsParser List<ExcelFileSection> materialSections = new ArrayList<ExcelFileSection>(); if (materialType.isDefinedInFileEntityTypeCode()) { - materialSections.addAll(ExcelFileSection.extractSections(multipartFile - .getInputStream())); + materialSections.addAll(ExcelFileSection.extractSections( + multipartFile.getInputStream(), excelSheetName)); } else { materialSections.add(ExcelFileSection.createFromInputStream( diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java index 4b8869559048400ea5d959f44b15855db67c8b9e..2ec3d7a6f1f2c4d978a6c844a7aa945eec0ad8e6 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java @@ -776,4 +776,11 @@ public final class GenericServer extends AbstractServer<IGenericServer> implemen return materialHelper; } + public void registerOrUpdateSamplesAndMaterials(final String sessionToken, + final List<NewSamplesWithTypes> newSamplesWithType, + List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException + { + registerOrUpdateMaterials(sessionToken, newMaterialsWithType); + registerOrUpdateSamples(sessionToken, newSamplesWithType); + } } diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java index 3962c33bd376af7f9cbc49ea787df7c535664ba3..9c1a2f1d88e26e2dde4e17bbcd70b252e0107ee9 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java @@ -275,4 +275,30 @@ final class GenericServerLogger extends AbstractServerLogger implements IGeneric .getExperimentType().getCode(), experiments.getUpdatedExperiments().size()); } + public void registerOrUpdateSamplesAndMaterials(final String sessionToken, + final List<NewSamplesWithTypes> newSamplesWithType, + List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException + { + StringBuilder samples = new StringBuilder(); + for (NewSamplesWithTypes s : newSamplesWithType) + { + if (samples.length() > 0) + { + samples.append(","); + } + samples.append(s.getEntityType().getCode() + ":" + s.getNewEntities().size()); + } + + StringBuilder materials = new StringBuilder(); + for (NewMaterialsWithTypes s : newMaterialsWithType) + { + if (materials.length() > 0) + { + materials.append(","); + } + materials.append(s.getEntityType().getCode() + ":" + s.getNewEntities().size()); + } + logTracking(sessionToken, "register_or_update_samples_and_materials", + "SAMPLES(%s) MATERIALS(%s)", samples.toString(), materials.toString()); + } } diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java index fe6a1c50295b98855b96422b7e68ba446226edec..7507775d932599857f3da6a517e52d68dcf62b3f 100644 --- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java +++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java @@ -139,6 +139,17 @@ public interface IGenericServer extends IServer @AuthorizationGuard(guardClass = NewSamplesWithTypePredicate.class) final List<NewSamplesWithTypes> newSamplesWithType) throws UserFailureException; + /** + * Registers or updates samples and materials of different types in batches. + */ + @Transactional + @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN) + @DatabaseCreateOrDeleteModification(value = + { ObjectKind.SAMPLE, ObjectKind.MATERIAL }) + public void registerOrUpdateSamplesAndMaterials(final String sessionToken, + final List<NewSamplesWithTypes> newSamplesWithType, + List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException; + /** * Updates samples of different types in batches. */ @@ -212,7 +223,8 @@ public interface IGenericServer extends IServer @Transactional @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN) @DatabaseCreateOrDeleteModification(value = ObjectKind.MATERIAL) - public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials) throws UserFailureException; + public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials) + throws UserFailureException; /** * Returns attachment described by given sample identifier, filename and version. diff --git a/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected b/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected index fe6a1c50295b98855b96422b7e68ba446226edec..7507775d932599857f3da6a517e52d68dcf62b3f 100644 --- a/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected +++ b/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected @@ -139,6 +139,17 @@ public interface IGenericServer extends IServer @AuthorizationGuard(guardClass = NewSamplesWithTypePredicate.class) final List<NewSamplesWithTypes> newSamplesWithType) throws UserFailureException; + /** + * Registers or updates samples and materials of different types in batches. + */ + @Transactional + @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN) + @DatabaseCreateOrDeleteModification(value = + { ObjectKind.SAMPLE, ObjectKind.MATERIAL }) + public void registerOrUpdateSamplesAndMaterials(final String sessionToken, + final List<NewSamplesWithTypes> newSamplesWithType, + List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException; + /** * Updates samples of different types in batches. */ @@ -212,7 +223,8 @@ public interface IGenericServer extends IServer @Transactional @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN) @DatabaseCreateOrDeleteModification(value = ObjectKind.MATERIAL) - public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials) throws UserFailureException; + public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials) + throws UserFailureException; /** * Returns attachment described by given sample identifier, filename and version. diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java index a5b26bc80809413e6ca481fad8e7cb79f7105e2a..8d8b043e29b174996a94eb3619d6584b4b2e6be3 100644 --- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java +++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java @@ -85,6 +85,10 @@ public final class Dict extends ch.systemsx.cisd.openbis.generic.client.web.clie public static final String EXACT_MATCH_ONLY = "EXACT_MATCH_ONLY"; + public static final String LIBRARY_IMPORT_MENU_ITEM = "LIBRARY_IMPORT_MENU_ITEM"; + + public static final String LIBRARY_IMPORT_TAB_TITLE = "LIBRARY_IMPORT_TAB_TITLE"; + public static final String WELLS_SEARCH_MENU_ITEM = "WELLS_SEARCH"; public static final String WELLS_SEARCH_SHOW_COMBINED_RESULTS = diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java index 19314c9b8b5a27ef80bc0189a8957596088d20df..bdd80dece9a79b70f929df1bad74035cceebdd34 100644 --- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java +++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java @@ -17,8 +17,8 @@ package ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application; import java.util.ArrayList; +import java.util.Arrays; import java.util.Collection; -import java.util.Collections; import java.util.List; import com.extjs.gxt.ui.client.widget.menu.MenuItem; @@ -37,6 +37,7 @@ import ch.systemsx.cisd.openbis.generic.shared.basic.dto.EntityKind; import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.IScreeningClientServiceAsync; import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.ExperimentAnalysisSummarySection; import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.ExperimentWellMaterialsSection; +import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.LibraryImportComponent; import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.WellSearchComponent; import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.locator.GlobalWellSearchLocatorResolver; @@ -62,7 +63,9 @@ public class ScreeningModule implements IModule ActionMenu globalWellSearch = TabActionMenuItemFactory .createActionMenu(viewContext, ID, createGlobalWellSearch()); - return Collections.singletonList(globalWellSearch); + ActionMenu globalLibraryImport = + TabActionMenuItemFactory.createActionMenu(viewContext, ID, createLibraryImport()); + return Arrays.asList(globalWellSearch, globalLibraryImport); } private ITabActionMenuItemDefinition<IScreeningClientServiceAsync> createGlobalWellSearch() @@ -95,6 +98,35 @@ public class ScreeningModule implements IModule }; } + private ITabActionMenuItemDefinition<IScreeningClientServiceAsync> createLibraryImport() + { + return new ITabActionMenuItemDefinition<IScreeningClientServiceAsync>() + { + + public String getName() + { + return Dict.LIBRARY_IMPORT_MENU_ITEM; + } + + public String getHelpPageTitle() + { + return "Global Library Import"; + } + + public String tryGetLink() + { + return null; + } + + public DatabaseModificationAwareComponent createComponent( + @SuppressWarnings("hiding") IViewContext<IScreeningClientServiceAsync> viewContext) + { + TabContent libraryImportTab = new LibraryImportComponent(viewContext); + return DatabaseModificationAwareComponent.wrapUnaware(libraryImportTab); + } + }; + } + public String getName() { return viewContext.getMessage(Dict.SCREENING_MODULE_TITLE); diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/detailviewers/LibraryImportComponent.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/detailviewers/LibraryImportComponent.java new file mode 100644 index 0000000000000000000000000000000000000000..cc7cf5a40878f9bed3d8f5aad762229ca2dde617 --- /dev/null +++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/detailviewers/LibraryImportComponent.java @@ -0,0 +1,199 @@ +package ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers; + +import static ch.systemsx.cisd.openbis.generic.client.web.client.application.framework.DatabaseModificationAwareField.wrapUnaware; + +import java.util.List; + +import com.extjs.gxt.ui.client.Style.Scroll; +import com.extjs.gxt.ui.client.event.ButtonEvent; +import com.extjs.gxt.ui.client.event.Events; +import com.extjs.gxt.ui.client.event.SelectionListener; +import com.extjs.gxt.ui.client.widget.form.Field; +import com.extjs.gxt.ui.client.widget.form.FileUploadField; +import com.google.gwt.user.client.Element; + +import ch.systemsx.cisd.openbis.generic.client.web.client.application.FormPanelListener; +import ch.systemsx.cisd.openbis.generic.client.web.client.application.IViewContext; +import ch.systemsx.cisd.openbis.generic.client.web.client.application.TabContent; +import ch.systemsx.cisd.openbis.generic.client.web.client.application.ui.AbstractRegistrationForm; +import ch.systemsx.cisd.openbis.generic.client.web.client.application.ui.file.BasicFileFieldManager; +import ch.systemsx.cisd.openbis.generic.shared.basic.dto.BatchRegistrationResult; +import ch.systemsx.cisd.openbis.plugin.generic.client.web.client.IGenericClientServiceAsync; +import ch.systemsx.cisd.openbis.plugin.generic.client.web.client.application.GenericViewContext; +import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.IScreeningClientServiceAsync; +import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.Dict; +import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.ScreeningModule; +import ch.systemsx.cisd.openbis.plugin.screening.shared.basic.dto.WellSearchCriteria.ExperimentSearchCriteria; + +/** + * Allows to specify search criteria for materials contained in wells. Used in experiment section + * panel or as a standalone module. + * + * @author Tomasz Pylak + */ +public class LibraryImportComponent extends TabContent +{ + + private static class LibraryImportForm extends AbstractRegistrationForm + { + protected final class RegisterOrUpdateSamplesAndMaterialsCallback + extends + AbstractRegistrationForm.AbstractRegistrationCallback<List<BatchRegistrationResult>> + { + RegisterOrUpdateSamplesAndMaterialsCallback( + final IViewContext<IGenericClientServiceAsync> viewContext) + { + super(viewContext); + } + + @Override + protected String createSuccessfullRegistrationInfo( + final List<BatchRegistrationResult> result) + { + final StringBuilder builder = new StringBuilder(); + for (final BatchRegistrationResult batchRegistrationResult : result) + { + builder.append("<b>" + batchRegistrationResult.getFileName() + "</b>: "); + builder.append(batchRegistrationResult.getMessage()); + builder.append("<br />"); + } + return builder.toString(); + } + } + + private static final String PREFIX = "library-import"; + + private static final String SESSION_KEY = PREFIX; + + private static final String FIELD_LABEL_TEMPLATE = "File"; + + private static final int NUMBER_OF_FIELDS = 1; + + private final BasicFileFieldManager fileFieldsManager; + + private final IViewContext<IGenericClientServiceAsync> genericViewContext; + + private static String createId(String sessionKey) + { + return ScreeningModule.ID + sessionKey; + } + + /** + * @param viewContext + */ + protected LibraryImportForm(IViewContext<IGenericClientServiceAsync> viewContext) + { + super(viewContext, createId(SESSION_KEY)); + + this.genericViewContext = viewContext; + setScrollMode(Scroll.AUTO); + fileFieldsManager = + new BasicFileFieldManager(SESSION_KEY, NUMBER_OF_FIELDS, FIELD_LABEL_TEMPLATE); + fileFieldsManager.setMandatory(); + addUploadFeatures(SESSION_KEY); + } + + @Override + protected final void onRender(final Element target, final int index) + { + super.onRender(target, index); + addFormFields(); + } + + @Override + protected void submitValidForm() + { + } + + @Override + protected void resetFieldsAfterSave() + { + for (FileUploadField attachmentField : fileFieldsManager.getFields()) + { + attachmentField.reset(); + } + } + + private final void addFormFields() + { + for (FileUploadField attachmentField : fileFieldsManager.getFields()) + { + formPanel.add(wrapUnaware((Field<?>) attachmentField).get()); + } + formPanel.addListener(Events.Submit, new FormPanelListener(infoBox) + { + @Override + protected void onSuccessfullUpload() + { + save(); + } + + @Override + protected void setUploadEnabled() + { + LibraryImportForm.this.setUploadEnabled(true); + } + }); + redefineSaveListeners(); + } + + void redefineSaveListeners() + { + saveButton.removeAllListeners(); + saveButton.addSelectionListener(new SelectionListener<ButtonEvent>() + { + @Override + public final void componentSelected(final ButtonEvent ce) + { + if (formPanel.isValid()) + { + if (fileFieldsManager.filesDefined() > 0) + { + setUploadEnabled(false); + formPanel.submit(); + } else + { + save(); + } + } + } + }); + } + + protected void save() + { + genericViewContext.getService().registerOrUpdateSamplesAndMaterials(SESSION_KEY, null, + true, new RegisterOrUpdateSamplesAndMaterialsCallback(genericViewContext)); + } + } + + private final IViewContext<IGenericClientServiceAsync> genericViewContext; + + public static String getTabTitle(IViewContext<IScreeningClientServiceAsync> viewContext) + { + return viewContext.getMessage(Dict.LIBRARY_IMPORT_TAB_TITLE); + } + + public LibraryImportComponent(IViewContext<IScreeningClientServiceAsync> screeningViewContext) + { + this(screeningViewContext, ExperimentSearchCriteria.createAllExperiments()); + + setContentVisible(true); + } + + public LibraryImportComponent(IViewContext<IScreeningClientServiceAsync> screeningViewContext, + ExperimentSearchCriteria experimentSearchCriteria) + { + super(getTabTitle(screeningViewContext), screeningViewContext, null); + this.genericViewContext = + new GenericViewContext(screeningViewContext.getCommonViewContext()); + } + + @Override + protected void showContent() + { + removeAll(); + add(new LibraryImportForm(genericViewContext)); + layout(); + } +} \ No newline at end of file diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js index ae30526965b0e29393ba003f57699b96cebf3756..2ebd7a10645d18b6b4999e087d35ae9914787682 100644 --- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js +++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js @@ -28,7 +28,8 @@ ANALYSIS_PROCEDURE: "Analysis Procedure", // WELLS_SEARCH_menu_item: "Wells Search", WELLS_SEARCH_tab_label: "Wells Search", - +LIBRARY_IMPORT_MENU_ITEM_menu_item: "Library Import", +LIBRARY_IMPORT_MENU_ITEM_tab_label: "Library Import", // // Experiment Viewer // diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java index 7cb80dd1fb53213cb468e1351c8121fdba4be830..0cfe4e51c42731bc780244c699000edb3714a61d 100644 --- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java +++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java @@ -109,7 +109,8 @@ class LibraryExtractor BatchSamplesOperation prepared = SampleUploadSectionsParser.prepareSamples(typeInFile, Arrays .asList(new NamedInputStream(new FileInputStream(platesFile), platesFile - .getName())), null, null, true, BatchOperationKind.REGISTRATION); + .getName())), null, null, true, null, + BatchOperationKind.REGISTRATION); List<NewSamplesWithTypes> samples = prepared.getSamples(); setUpdatableTypes(samples); return samples;