DiversityTaxonomy, Supertype-Subtype model


This is a documentation of an earlier, more detailed model for nomenclature and taxonomy that has not been further pursued. In it, the TaxonomyName entity is formulated as a supertype-subtype structure. The common attributes are in the supertype TaxonomyName and 4 exclusive subtypes exist for higher taxa (TaxonomyHigherTaxa), genera (TaxonomyGenus), infrageneric taxa (TaxonomyInfraGenericTaxon), and infraspecific taxa and species (TaxonomySpecies; this could have been separated into two subtypes again). Each entity of TaxonomyName must have exactly one these four subtype entities linked to it.

Note that the introduction of a supertype is not only an implementation issue (to implement common attributes only once), but also deduced from the requirement that a single ID must be provided for all taxa, regardless of rank. If the taxonomy database subsystem is used from other subsystems, in many cases (e.g. identification of specimen, morphological descriptions) the same link may point to taxa ranging from infraspecific taxa to family or even higher. For example, it is indeed possible that an identification can only assert that the species must belong to Basidiomycetes.

The advantage of the model using entities as subtype is that the relationship between the subtypes can be defined in more detail. For example the genus or higher taxon type can only be a species of genus, respectively. However, since the relational database management systems used (Jet and SQL Server) do not support supertype/subtype explicitly, and since the aim of the model is relative simplicity, rather than completeness, the supertype and subtype attributes have been combined in all newer models into the single entity TaxonomyName. The basic supertype-subtype structure is maintained, albeit simplified and less visible in the new model: Instead of linking entities, groups of attributes must be used alternatively.

An empty Microsoft Access 2000 database implementing this model is provided for archiving purposes. See the selfextracting archive DiversityTaxonomy_SupertypeSubtype.exe.

Gregor Hagedorn, 11.Jan.2001.


Entity relationship diagram of DiversityTaxonomy (supertype-subtype version, archived Jan. 2001)

Entity relationship diagram of DiversityTaxonomy (supertype-subtype version, archived Jan. 2000) TaxonomyName, click to show attributes TaxonomySpecies, click to show attributes TaxonomyGenus, click to show attributes TaxonomyInfraGenericTaxon, click to show attributes TaxonomyHigherTaxon, click to show attributes TaxonomyActionOnName, click to show attributes TaxonomySynonymy, click to show attributes TaxonomyHierarchy, click to show attributes TaxonomyOpinion, click to show attributes

(You can click on the entities to go to the attribute tables.)


TaxonomyName

Taxonomy: Supertype entity, providing a nomenclatural ID for all names introduced as taxa (infraspecific, species, genus, family, etc.). Contains only objective information; all scientific opinion is placed in ...Opinion, ...Synonymy, & ...Hierarchy.

Attributes and indices of the entity 'TaxonomyName'
Name Type Description / Default value & validation Rqrd./Index
NomID Autonumber Unique ID code for the nomenclatural name.
Default value: GenUniqueID()
- I (U)
TaxonomicRank Text (20) Taxonomic rank of the taxon (var., subsp., species, genus, family, order, etc.). R I
ConceptSuffix Text (255) 'sensu' or 'emend.' author, 's.str.'/'s.lat.'. This attribute does not really belong here, since multiple taxon concepts can be based on a single name. Provided as sep. attribute to simplify later changes. Compare 'potential taxon' sensu Berendsohn! - -
ProtologueReportedCitation Text (255) Optional text of citation; used only when default reference description is unsatisfactorily (esp. abbreviated tax. literature book titles, exsiccata references). If present, this information is used in preference over the ProtologueRefDescription. - -
ProtologueRefID Text (20) Reference ID of the original description/protologue. Refers to the ID code of the main ReferenceTitle table in the reference module (= foreign key). - I
ProtologueRefDescriptionCache Text (255) Calculated: cached reference description, obtained through the ProtologueRefID from the references subsystems. - -
ProtologueRefPage Text (50) First page of protologue (original description) in the reference. - -
ProtologueRefReprintPagination Boolean If checked (or 'True'), the true page number of the protologue page is unknown and only a reprint page number (pagination starting w. 1...) can be given. In tax. monographs this situation is often indicated by 'extr.' or 'extractum' after the page number. R -
OriginalNameSpelling Text (255) Original spelling of taxonomic name in the protologue publication, if different from current taxon name. - -
OriginalTaxonPlacement Text (255) Taxonomic placement (e.g. family or division) mentioned in the original description. This is NOT the current taxonomic placement! - -
OriginalDiagnosisLatin Memo Optional: The full text of the Latin description/diagnosis in the protologue. - -
OriginalDiagnosisOther Memo Optional: The full text of the original description in the protologue, if a diagnosis in another language than Latin was provided. To be entered into the database only if no copyright is violated. - -
IndexingReference Text (255) Optional: A secondary reference indexing this taxon, e.g. Saccardo, Index of Fungi, etc. Entered as text, not as reference ID! - -
ImportedFrom Text (255) If imported from another database: The name of the database system or provider. Otherwise empty. - -
ImportedID Text (255) If imported from another database: An ID value to later re-identify the record in that database may be stored here. - -
Problem Text (255) Problem with data entry (not with the taxon). - -
LogCreated_User Text (255) Name of user who first entered (typed or imported) the data. This is the operator (or typist) name, which may be different from the person responsible. R -
LogCreated_Date Date/Time Date and time when record was first entered (typed or imported) into this system.
Default value: Now()
R -
NameCache Text (255) Calculated: Full, standardized name for the new taxon, calculated from genus, species and infraspecific epithet and authors. The value is unique, since it includes the author for higher taxa (genera, families) as well as for species. R I (U)
NameCache_html Text (255) Calculated: Like NameCache, but italic and plain text is formatted using xhtml markup (/). R -
NameCache_NoAuthors Text (255) Calculated: Like NameCache, but without any authors. Duplicates may occur here, and taxa with homonyms can be detected using this attribute. Where no homonyms are found, names from other data sources may be compared based on this field alone. R I
NameCache_inverted Text (255) Calculated: Like NameCache, but for species or infraspecific taxa the lowest rank name is printed first ('species-epitheton, Genus' or 'variety (var.) species-epitheton, Genus'). R I (U)
Relation type:  Fields involved
Referential integrity  TaxonomyName.NomID « TaxonomyHierarchy.Parent_NomID
Updates cascade, one-to-one  TaxonomyName.NomID « TaxonomyInfraGenericTaxon.InfraGenericID
Deletions cascade  TaxonomyName.NomID « TaxonomyActionOnName.NomID
Deletions cascade, one-to-one  TaxonomyName.NomID « TaxonomyGenus.GenusID
Referential integrity  TaxonomyName.NomID « TaxonomyHierarchy.NomID
Deletions cascade, one-to-one  TaxonomyName.NomID « TaxonomyHigherTaxon.HigherTaxonID
Referential integrity  TaxonomyName.NomID « TaxonomyOpinion.NomID
Deletions cascade, one-to-one  TaxonomyName.NomID « TaxonomySpecies.SpeciesID

TaxonomyInfraGenericTaxon

Taxonomy: Nomenclatural information relating to the introduction of infrageneric taxa (between species and genus). This is a subtype of the supertype entity TaxonomyName.

Attributes and indices of the entity 'TaxonomyInfraGenericTaxon'
Name Type Description / Default value & validation Rqrd./Index
InfraGenericID Long Unique ID code of the higher taxon. Refers to the NomID code of TaxonomyName (= foreign key). R I (U)/I (U)
InfraGenericTaxonName Text (255) Name of taxon above species level, excluding genera (currently accepted spelling). R I (U)
TaxonAuthors Text (255) Author of the taxon. - -
TypeSpecies_NomID Long Type species of infrageneric taxon. Refers to the ID code of TaxonomyName (= foreign key). - I/I
Relation type:  Fields involved
Updates cascade, one-to-one  TaxonomyName.NomID « TaxonomyInfraGenericTaxon.InfraGenericID
Updates cascade  TaxonomySpecies.SpeciesID « TaxonomyInfraGenericTaxon.TypeSpecies_NomID

TaxonomyGenus

Taxonomy: Nomenclatural information relating to the introduction of a genus. This is a subtype of the supertype entity TaxonomyName.

Attributes and indices of the entity 'TaxonomyGenus'
Name Type Description / Default value & validation Rqrd./Index
GenusID Long Unique ID code of the genus. Refers to the NomID code of TaxonomyName (= foreign key). R I (U)/I (U)
GenusName Text (255) Genus name (currently accepted spelling). R I (U)
GenusAuthors Text (255) Author of the genus. - -
TypeSpecies_NomID Long Type species of genus. Refers to the ID code of TaxonomyName (= foreign key). - I/I
AsexualGenus Boolean Checked (or true): The genus is an anamorph genus, containing asexual forms only (relevant for fungi). This information can often also be obtained from the taxonomic hierarchy; it is added here to be available when the hierarchy is yet unfinished.
Default value: Null
- -
Relation type:  Fields involved
Referential integrity  TaxonomyGenus.GenusID « TaxonomyHigherTaxon.TypeGenus_NomID
Referential integrity  TaxonomyGenus.GenusID « TaxonomySpecies.Genus_NomID
Referential integrity  TaxonomySpecies.SpeciesID « TaxonomyGenus.TypeSpecies_NomID
Deletions cascade, one-to-one  TaxonomyName.NomID « TaxonomyGenus.GenusID

TaxonomySpecies

Taxonomy: Nomenclatural information relating to the introduction of scientific specific and subspecific names. This is a subtype of the supertype entity TaxonomyName.

Attributes and indices of the entity 'TaxonomySpecies'
Name Type Description / Default value & validation Rqrd./Index
SpeciesID Long Unique ID code of the species/infraspecific taxon. Refers to the NomID code of TaxonomyName (= foreign key). - I (U)/I (U)
Genus_NomID Long Genus name. Refers to the ID code of TaxonomyGenus (= foreign key). R I/I
SpeciesEpithet Text (255) Species epithet, for example 'alba' in 'Abies alba Miller' (currently accepted spelling). R I
SpeciesAuthor Text (255) Authors of the species, abbreviated according to authors standard (empty for infraspecific taxa except autonyms; autonym example: 'Abies alba Miller ssp. alba'; infraspecific example: 'Abies alba ssp. nebrodensis (Lojac.) Nitz.'). - -
InfraspecificName Text (255) Infraspecific epitheton (currently accepted spelling). Note: the rank is known from required attribute TaxonomicRank in TaxonomyName (= the supertype entity). - I
InfraspecificAuthor Text (255) Authors of the infraspecific name (empty for infraspecific autonyms like Abies alba alba). - -
CreationType Text (1) T: New taxon; C: new combination based on a previously published other name, N: new name ('nom.nov.') introduced to replace a homonym, V: validation of previously invalidly published taxon name, or U: for unknown.
Default value: "U"
R -
Basionym_NomID Long Basionym. Filled only if the new name is a combination, replacement, or validation based on another name and has the same type material. Refers to the ID code of TaxonomyName (= foreign key). - I/I
ProtologueTypeInformation Text (255) Information on deposition/location of type material, entered exactly as mentioned in the protologue (original taxon description). - -
Relation type:  Fields involved
Referential integrity  TaxonomyGenus.GenusID « TaxonomySpecies.Genus_NomID
Referential integrity  TaxonomySpecies.SpeciesID « TaxonomyGenus.TypeSpecies_NomID
Updates cascade  TaxonomySpecies.SpeciesID « TaxonomyInfraGenericTaxon.TypeSpecies_NomID
Referential integrity  TaxonomySpecies.SpeciesID « TaxonomySpecies.Basionym_NomID
Referential integrity  TaxonomySpecies.SpeciesID « TaxonomySynonymy.Accepted_NomID
Referential integrity  TaxonomySpecies.SpeciesID « TaxonomySynonymy.Syn_NomID
Deletions cascade, one-to-one  TaxonomyName.NomID « TaxonomySpecies.SpeciesID

TaxonomyActionOnName

Taxonomy: Secondary action, affecting the status of a taxon. Examples are neo-, lecto- or epitypifications and conservation/rejection.

Attributes and indices of the entity 'TaxonomyActionOnName'
Name Type Description / Default value & validation Rqrd./Index
ActionID Autonumber Unique ID for this record. - I (U)
NomID Long The taxon concerning this action. Refers to the NomID code of TaxonomyName (= foreign key). R I/I
ActionType Text (1) Type of nomenclatural action: conservation, rejection, neo-, lecto- or epitypification, emendation. The sanctioning of a name should not be recorded here. R -
InternalNote Memo Additional information regarding the typification or conservation/rejection. - -
RefID Text (20) Reference ID of the reference containing the nomenclatural action defined in ActionType. Refers to the ID code of the main ReferenceTitle table in the reference module (= foreign key). R I
RefDescriptionCache Text (255) Calculated: cached reference description, obtained through the RefID from the references subsystems. - -
RefPage Text (50) Relevant detail in a nomenclatural action reference; usually number of the page on which the action is described. - -
LogCreated_User Text (255) Name of user who first entered (typed or imported) the data. This is the operator (or typist) name, which may be different from the person responsible. R -
LogCreated_Date Date/Time Date and time when record was first entered (typed or imported) into this system.
Default value: Now()
R -
Relation type:  Fields involved
Deletions cascade  TaxonomyName.NomID « TaxonomyActionOnName.NomID

TaxonomyOpinion

Taxonomy: Opinion or comment relating to the status (valid, accepted, etc.) of a nomenclatural name.

Attributes and indices of the entity 'TaxonomyOpinion'
Name Type Description / Default value & validation Rqrd./Index
NomID Long The taxon this opinion refers to. Refers to the NomID code of TaxonomyName (= foreign key). - I
ProjectMarker Text (255) Each project can have a different opinion regarding synonmy. Refers to the common project definition in the user module. R I (UM)
Responsible Text (255) The person responsible for this opinion/assessment on a taxon.
Validation rule: Not Is Null, validation message: Any opinion must be signed by a responsible person.
R -
Status Text (1) Status of taxonomic name: A=accepted, D=Doubtful, E=Excluded, etc. - I
UserMarker1 Text (255) A temporary marker assigned by user for searching and sorting purposes while a group is reviewed. Any information can be entered here, but it will be visible only internally. - I
UserMarker2 Text (255) A temporary marker assigned by user for searching and sorting purposes while a group is reviewed. Any information can be entered here, but it will be visible only internally. - I
TypeInformation Text (255) List of known type collections, use a '!' after collection name/abbreviation to indicate that this material has been studied by the responsible person. - -
ReportedNote Memo Taxonomic remarks that will be output after the taxon in a report. - -
InternalNote Memo An internal note of the responsible person concerning this name. This information is NOT included in any report. R -
RefID Text (20) If the opinion is based on a publication: the reference ID of that work. - I
RefDescriptionCache Text (255) If the opinion is based on a publication: the reference description of that work. - -
RefPage Text (50) If the opinion is based on a publication: relevant detail; usually page number where the opinion is published. - -
Problem Text (255) Temporary problem with data entry (not with the taxon, cmp. ReportedNote/InternalNote for permanent notes on problems). - -
CheckPlausible_User Text (255) Name of user responsible for a first plausibility or consistency check. User and Date are automatically filled if 'Original check' performed directly. - -
CheckPlausible_Date Date/Time Date and time when plausibility/consistency was checked (i.e. data entry rules and spelling errors checked, no comparison with original publication). - -
CheckOriginal_User Text (255) Name of user responsible for comparison of taxon record with original publication. - -
CheckOriginal_Date Date/Time Date and time when entry was compared with the original publication. - -
LogCreated_User Text (255) Name of user who first entered (typed or imported) the data. This is the operator (or typist) name, which may be different from the person responsible. R -
LogCreated_Date Date/Time Date and time when record was first entered (typed or imported) into this system.
Default value: Now()
R -
Relation type:  Fields involved
Referential integrity  TaxonomyName.NomID « TaxonomyOpinion.NomID

TaxonomySynonymy

Taxonomy: Synonymization of species. Each responsible user can create an independent system.

Attributes and indices of the entity 'TaxonomySynonymy'
Name Type Description / Default value & validation Rqrd./Index
ProjectMarker Text (255) Each project can have a different opinion regarding synonmy. Refers to the common project definition in the user module. R I (UM)
Syn_NomID Long Synonym name. Refers to the NomID code of TaxonomyName (= foreign key). R I
ProParteSynID Byte 0 = only a single accepted name is possible for a given synonym. 1..255 = multiple valid names are allowed for pro parte ('p.p.') synonyms. Use 1 for the first pro parte name, 2 for the second, and so on. Please do not use 0 for 1st, 2nd, etc. name!
Default value: 0
R -
Accepted_NomID Long Accepted name within a project. Refers to the NomID code of TaxonomyName (= foreign key). R I/I
ObligateSynonym Boolean True (= checked) indicates an obligate synonym, based on the same type; False (= empty) a facultative (or taxonomic) synonym. Null (= gray checkbox) indicates that the synonymization status could not be decided.
Default value: Null
- -
SynonymyTypeCache Text (1) @@ Teleomorph?? Unknown?? Type of Synonymy: Normal synonym (N), anamorph of a teleomorph (A), or synanamorph (S). Calculated from AsexualGenus marker in the Genus. - -
InternalNote Memo An internal note of the responsible person concerning this synonymization. This information is NOT included in any report. R -
RefID Text (20) If the synonymization is based on a publication: the reference ID of that work. Refers to the ID code of the main ReferenceTitle table in the reference module (= foreign key). - I
RefDescriptionCache Text (255) If the synonymization is based on a publication: the reference description of that work. - -
RefPage Text (50) If the synonymization is based on a publication: relevant detail; usually page number where the synonymization is published. - -
LogCreated_User Text (255) Name of user who first entered (typed or imported) the data. This is the operator (or typist) name, which may be different from the person responsible. R -
LogCreated_Date Date/Time Date and time when record was first entered (typed or imported) into this system.
Default value: Now()
R -
Relation type:  Fields involved
Referential integrity  TaxonomySpecies.SpeciesID « TaxonomySynonymy.Accepted_NomID
Referential integrity  TaxonomySpecies.SpeciesID « TaxonomySynonymy.Syn_NomID

TaxonomyHierarchy

Taxonomy: Hierarchy above the species. Each responsible user can create an independent taxonomic system.

Attributes and indices of the entity 'TaxonomyHierarchy'
Name Type Description / Default value & validation Rqrd./Index
ProjectMarker Text (255) Each project can implement a different taxonomic hierarchy. Refers to the common project definition in the user module. - I (UM)
NomID Long Unique ID code of the higher taxon. Refers to the NomID code of TaxonomyName (= foreign key). - I/I
Parent_NomID Long Next higher taxon (e.g. the family or subfamily if this taxon is a genus). R I/I
ReportedNote Text (255) Taxonomic remarks that will be output after the taxon in a report. - -
InternalNote Memo An internal note of the responsible person concerning this taxon. This information is NOT included in any report. - -
RefID Text (20) If the classification is based on a publication: the reference ID of that work. - I
RefDescriptionCache Text (255) If the classification is based on a publication: the reference description of that work. - -
RefPage Text (50) If the classification is based on a publication: relevant detail; usually page number where the opinion is published. - -
LogCreated_User Text (255) Name of user who first entered (typed or imported) the data. This is the operator (or typist) name, which may be different from the person responsible. - -
LogCreated_Date Date/Time Date and time when record was first entered (typed or imported) into this system.
Default value: Now()
- -
HierarchyListCache Text (255) CALCULATED FIELD: List of higher taxa for faster access: "div.; class; ord.; fam.". - -
Relation type:  Fields involved
Referential integrity  TaxonomyName.NomID « TaxonomyHierarchy.Parent_NomID
Referential integrity  TaxonomyName.NomID « TaxonomyHierarchy.NomID

TaxonomyChanges

Taxonomy: A technical log of changes of taxonomic or nomenclatural information maintained automatically by the database (user, date, entities & attributes affected).

Attributes and indices of the entity 'TaxonomyChanges'
Name Type Description / Default value & validation Rqrd./Index
NomID Long The ID of the taxon that was changed by the user. Refers to the NomID code of TaxonomyName (= foreign key). R I
Changes Memo Attributes and data affected by changes, details of changes. R -
LogUpdated_User Text (255) Name of user who last updated the record. This is the operator (or typist) name, which may be different from the person responsible. R -
LogUpdated_Date Date/Time Date and time of last update of the record. R I (UM)
s_GUID GUID (system attribute used in database replication).
Default value: GenGUID()
- I (U)
s_Generation Long (system attribute used in database replication). - I
s_Lineage OLE Object (system attribute used in database replication). - -

TaxonomyHigherTaxon

Taxonomy: Nomenclatural information relating to the introduction of higher taxa (above the genus). This is a subtype of the supertype entity TaxonomyName.

Attributes and indices of the entity 'TaxonomyHigherTaxon'
Name Type Description / Default value & validation Rqrd./Index
HigherTaxonID Long Unique ID code of the higher taxon. Refers to the NomID code of TaxonomyName (= foreign key). R I (U)/I (U)
HigherTaxonName Text (255) Name of taxon above species level, excluding genera (currently accepted spelling). R I (U)
TaxonAuthors Text (255) Author of the taxon. - -
TypeGenus_NomID Long Type genus of taxon. Refers to the ID code of TaxonomyName (= foreign key). - I/I
Relation type:  Fields involved
Referential integrity  TaxonomyGenus.GenusID « TaxonomyHigherTaxon.TypeGenus_NomID
Deletions cascade, one-to-one  TaxonomyName.NomID « TaxonomyHigherTaxon.HigherTaxonID

Footnotes: The following abbreviations have been used in the tables: R: It is required to enter data in this field. I: The field is indexed to allow fast searching. different types of indices are denoted by additional letters in parentheses: U = unique index, N = Null values are ignored in the index, M = the index contains more than one attribute. Note that all attributes that are part of the primary key index are underlined in the first column.


Documentation last revised on 19.Jan.2001 02:15, last page update: 2005-03-30.

This work is licensed under a Creative Commons License Valid XHTML 1.0! Valid CSS1!