| Data about specimens  
						Fields are shown under each table.  Comments about future
							changes or unresolved design issues are shown in contrasting color.  Version specific features are noted by highlighted text. 
						tblSpecimens, information about specimens
							
								SpecimenID, integer, 4 bytes, identifier for specimenTaxonNameID, integer, 4 bytes, = tblTaxon.TaxonNameID of a valid or unnamed taxon
									that is the current identification (may be higher level taxon if not identified
									further)DepoID, integer, 2 bytes, = tblDepos.DepoID, identifier for depository or collection
									that owns the specimen, a negative value means that the depository is not certainDepoCatNo, text, 30 bytes maximum, catalogue number of the depository or collectionPreparationCode, integer, 1 byte, 0 = unspecified, 1 = pin, 2 = vial, 3 = jar,
									4 = alcohol (vial or jar not specified), 5 = microscope slide 
									dropped in version 4.0MaleCount, integer, 2 bytes, number of adult males (-1 means "many", -2 means "more
									than 1") dropped in version 4.0FemaleCount, integer, 2 bytes, number of adult females (-1 means "many", -2 means
									"more than 1") dropped in version 4.0UnsexedAdultCount, integer, 2 bytes, number of unsexed adults (-1 means "many",
									-2 means "more than 1") dropped in version 4.0ImmatureCount, integer, 2 bytes, number of juveniles (-1 means "many", -2 means
									"more than 1") dropped in version 4.0SpecimenStatusID, integer, 1 byte, = tblSpecimenStatus.SpecimenStatusID, (OK, damaged,
									lost, etc.)LocalityID, integer, 4 bytes, = tblLocalities.LocalityID, identifier for the localityCollectEventID, integer, 4 bytes, = tblCollectEvents.CollectEventID, identifier
									for the collecting eventDataFlags, integer, 1 byte, bit flags for kinds of data available
									
										1 = ecological relationship2 = character data, not yet implemented 4 = image8 = sound16 = include specimen locality in maps, 
											implemented in version 3.5SourceID, integer, 2 bytes, = tblSources.SourceID, source for the data in this
									tableNote, text, 300 bytes maximum, condition of specimen or any other informationAccessCode, integer, 2 bytesLastUpdate, smalldatetime, date and time of last updateModifiedBy, integer, 2 bytes, UserID of the signon that made the changePreparationType, text, 300 byte maximum, text field replacing PreparationCode, 
									added in version 4.0BasisOfRecord, integer, 4 bytes, added in version 4.0
									
										0 = 'Not specified'1 = 'Preserved specimen'2 = 'Fossil specimen'3 = 'Image (still or video)'4 = 'Audio recording'5 = 'Checklist/Literature/Map'6 = 'Personal observation'tblSpecimenCategories, categories of specimens (male, female, egg, etc.) 
							added in version 4.0
							
								SpmnCategoryID, integer, 2 bytes, primary key, identifier for the categoryName, text, 30 characters maximumSeqNum, integer, 2 bytes, used to specify the list sequence in dropdownlistsLastUpdate, smalldatetime, date and time of last updateModifiedBy, integer, 2 bytes, UserID of the signon that made the changetblSpecimenCounts, counts for various specimen categories
							added in version 4.0
							
								SpecimenID, integer, 4 bytes, = tblSpecimens.SpecimenID, identifier for 
									specimenSpmnCategoryID, integer, 2 bytes, identifier for the categoryCount, integer, 2 bytes, (-1 means "many", -2 means "more than 1")LastUpdate, smalldatetime, date and time of last updateModifiedBy, integer, 2 bytes, UserID of the signon that made the changetblDepos, depositories (institutions or collections) that hold type 
							specimens, including duplicate names
							
								DepoID, integer, 2 bytes, identifier for the type depositoryPrefID, integer, 2 bytes, = tblDepos.DepoID for the preferred nameCoden, text, 5 bytes maximum, standard specimen depository abbreviations as specified 
									by the Bishop MuseumShortName, text, 40 bytes maximum, city plus descriptive abbreviation if city has 
									multiple depositories; null string if this is not a preferred nameFullName, text, 150 bytes maximum, full name for the depository, including duplicate namesLink, text, 75 bytes maximum, hyperlink to depository's websiteLastUpdate, smalldatetime, date and time of last updateModifiedBy, integer, 2 bytes, UserID of the person that made the changetblSpecimenStatus, sex and maturity classification for specimens, 
							shared across files.
							
								SpecimenStatusID, integer, 1 byte, identifier for the statusStatus, text, 20 characters maximum
								
									0 = presumed OK1 = missing2 = destroyed3 = lost4 = unknown5 = missing?6 = destroyed?7 = lost?8 = damaged9 = damaged?10 = no data enteredtblSexes, sex and maturity classification for type series, shared across files.
								SexID, integer, 1 byte, identifier for the descriptionSex, text, 22 bytes maximum, description consisting of male, female, juv., etc.Letter, text, 4 characters, letter(s) used in imported data to specify sex tblIdentifications, record of identifications on labels
							or in publications or by placement in trays.  Each identification must have
							either HigherTaxonName or a genus name that can be located via NomenclatorID. 
							If the genus is specified, then HigherTaxonName is left blank.  RefID, IdentifierName,
							PlaceInCollection, and IdentificationModeNote are the four possible sources of identification. 
							At least one source of identification must be stated.  Placement in collection
							is considered not worth recording if one of the other sources is listed. If the
							identification is from the literature, then RefID > 0.  In that case, names
							of subgenera, genera and higher taxa must be present in tblTaxa.  If RefID
							= 0, names of taxa are not required to be present in tblTaxa.
							
								SpecimenID, integer, 4 bytes, = tblSpecimens.SpecimenIDSeqNum, integer, 2 bytes, sequence number for identifications for this specimen;
									SpecimenID and SeqNum together form the primary keyHigherTaxonName, text, 30 bytes maximum, name of taxon higher than genus rank,
									used only when there is no identification at genus rankNomenclatorID, integer, 4 bytes, = tblNomenclator.NomenclatorIDTaxonIdentNote, text, 300 bytes maximum, any additional taxon related information
									contained with the identificationTypeKindID, integer, 1 byte, = tblTypeKinds.TypeKindID; kind of type, 0 if noneTopotype, integer, 1 byte, 0 = not a topotype, 1 = is a topotypeTypeTaxonNameID, integer, 4 bytes.  If TypeKindID and Topotype both = 0, then
									TypeTaxonNameID = 0.  If either TypeKindID or Topotype > 0, then TypeTaxonNameID
									= tblTaxa.TaxonNameID of the name for which this specimen is a type.RefID, integer, 4 bytes, = tblRefs.RefID, published reference with this specimen
									identifiedIdentifierName, text, 50 bytes maximum, name of person on identification label. 
									To be deleted when linking table to tblPeople is available.IdentifierID, integer, 2 bytes, = tblPeople.PersonID.  
									For future implementation, probably in a separate linking table.Year, integer, 2 bytes, year stated on an identification labelPlaceInCollection, integer, 1 byte, 0 = not the source of the identification, 1
									= the identification information is based solely on the placement in a collectionIdentificationModeNote, text, 200 bytes maximum, information about the source of
									the identificationLastUpdate, smalldatetime, date and time of last updateModifiedBy, 2 bytes, UserID of the signon that made the changeIdentQualifier, text, 30 character maximum.  Added in version 4.1.VerbatimLabel, text, 1000 character maximum.  Added in version 4.1.tblTypeKinds, holotype, lectotype, neotype, etc., shared across files.
								TypeKindID, integer, 1 byte, identifier for the kind of type
									
										0 = undefined1 = holotype2 = syntypes3 = neotype4 = lectotype5 = unspecified primary type6 = unknown7 = allotype8 = paratype9 = topotype10 = paralectotypeKind, text, 50 bytes maximum, name for the kind of typeLetter, text, 1 character, letter used in imported data to specify kindtblLocalities, information about localities where specimens
							were found.
							
								LocalityID, integer, 4 bytes, identifier for localityLevel1ID, 1 character, = tblGeoLevel1.Level1ID Level2ID, 1 character, = tblGeoLevel2.Level2ID Level3ID, 3 characters, = tblGeoLevel3.Level3ID Level4ID, 3 characters, = tblGeoLevel4.Level4ID GeoID, calculated as concatenation of above 4 columnsLatitude, decimal, precision 7, scale 4, degrees (+ for N, - for S)Longitude, decimal, precision 7, scale 4, degrees (+ for E, - for W)PrecisionCode, integer, 1 byte (still available, no longer used, will be converted for use as indicator of confidence in the supplied Lat/Long)
									
										0 = unspecified (default)1 = from locality label2 = estimated from map and locality label3 = based on county or similar modest area specified on locality label4 = estimated from less specific locality labelElevation, integer, 2 bytes, elevation in metersMaxElevation, integer, 2 bytes, maximum elevation when there is a range, otherwise
									nullTimePeriodID, integer, 2 bytes, = tblTimePeriods.TimePeriodID, geologic time periodLocalityDetail, text, 300 bytes maximum, place data not coded in any other fieldTimeDetail, text, 300 bytes maximum, details not coded in TimePeriodIDLastUpdate, smalldatetime, date and time of last update ModifiedBy, integer, 2 bytes, UserID of the signon that made the changeDataFlags, integer, 1 byte, bit flags for data status, added in version 4.0
									
										1 = The disparity between geographic levels and the Latitude & Longitude was accepted by the user2 = The locality was last edited by a user during a localities test runCountry, text, 100 characters maximum, name of the country of collection (It is not required that this name match any data supplied in the GeoId (above)), added in version 4.0State, text, 100 characters maximum, name of the state or province of collection, added in version 4.0County, text, 100 characters maximum, name of the county or precinct of collection, added in version 4.0BodyOfWater, text, 100 characters maximum, name of the body of water of collection, added in version 4.0PrecisionRadius, interger, 4 bytes, radius of the circle ot uncertainty of the accuarcy of the Latitude/Longitude data, added in version 4.0LatLongFrom, integer, 4 bytes, indicator of when the Latitude/Longitude data was applied, added in version 4.0
									
										0 = Unknown (default)1 = Provided by the collector at collection time2 = Provided during data entrytblGeoLevel1, shared across files, continent or other major part of the 
							world.  This table and the next two tables are copied from Brummitt, R. K. 2001: World 
							Geographical Scheme for Recording Plant Distributions. Plant Taxonomic Database Standards No. 2, 
							Edition 2. International Working Group on Taxonomic Databases (TDWG).  Hunt Institute for 
							Botanical Documentation, Pittsburgh.  [TDWG Standard] [Electronic version available under 
							http://www.tdwg.org/geo2.htm.] 
							NOTE:  The row for no information (Level1ID = "0") has information for columns from 
							MinL2AreaValue to Level2AllMask that applies to tblTaxa.Distribution1Flags, not to 
							tblTaxa.Distribution2WFlags, Distribution2CFlags or Distribution2EFlags.
							
								Level1ID, character, 1 byte, identifier for "continent"Name, text, 16 bytes maximum, nameBitValue, integer, 4 bytes, value of the bit that indicates this level 1 area in 
									tblTaxa.Distribution1FlagsMinL2AreaValue, integer, 4 bytes, value of the lowest bit in tblTaxa.Distribution2WFlags, 
									Distribution2CFlags or Distribution2EFlags that signifies a subarea within this level 1 
									area.  Deleted in version 3.5.MaxL2AreaValue, integer, 4 bytes, value of the highest bit in tblDistribution.AreaFlags 
									that signifies a subarea within this level 1 areaLevel2AreaMask, integer, 4 bytes, mask for all the bits in tblDistribution.AreaFlagsLevel2StatusFactor, integer, 4 bytes, value of the lower bit in tblTaxa.Distribution2WFlags, 
									Distribution2CFlags or Distribution2EFlags for the status of information.  
									Deleted in version 3.5.Level2StatusMask, integer, 4 bytes, mask for the two status bits (= 3 * 
									Level2StatusFactor). Deleted in version 3.5.Level2AllMask, integer, 4 bytes, combined bit values for Level2AreaMask and 
									Level2StatusMask.  Deleted in version 3.5.tblGeoLevel2, shared across files, region or large country.  
							From World Geographical Scheme for Recording Plant Distributions, Plant Taxonomic Database 
							Standards No. 2. Edition 2.
							
								Level1ID, character, 1 byte, = tblGeoLevel1.Level1ID Level2ID, character, 1 byte, identifier for region within "continent"Name, text, 50 bytes maximum, name for the regionBitValue, integer, 4 bytes, value of the bit in tblDistribution.AreaFlags that 
									indicates this level 2 areaLevel3Count, integer, 1 byte, count of level 3 areas contained in this level 2 areaMaxL3AreaValue, integer, 4 bytes, maximum bit value in tblLevel3Dist for a contained areaLevel3AreaMask, integer, 4 bytes, mask for level 3 area flags in tblLevel3Dist.AreaFlagstblGeoLevel3, shared across files, country or portion of large 
							country.  From World Geographical Scheme for Recording Plant Distributions, Plant 
							Taxonomic Database Standards No. 2. Edition 2.
							
								Index3, integer, 2 bytes, = 2000 * Level1ID + 100 * (Level2ID + 1) + sequence number of 
									Level3ID in alphabetic order among rows with the same Level1ID and Level2ID.  When 
									Level3ID = "---", the sequence number is treated as 0.Level1ID, character, 1 byte, = tblGeoLevel1.Level1ID Level2ID, character, 1 byte, = tblGeoLevel2.Level2IDLevel3ID, character, 3 bytes, identifier for "country" within regionName, text, 50 bytes maximum, name for the regionExpandedName, text 100 bytes maximum, includes identifying name (usually 
									tblGeoLevel2.Name) before tblGeoLevel3.NameBitValue, integer, 4 bytes, value of the bit that indicates this level 3 areatblGeoLevel4, shared across files, county or other smaller 
							area.  From World Geographical Scheme for Recording Plant Distributions, Plant Taxonomic 
							Database Standards No. 2. Edition 2 and from United States Federal Information Processing 
							Standards Publication 6-4 (http://www.itl.nist.gov/fipspubs/fip6-4.htm) and other sources.
							
								Level3ID, character, 3 bytes, = tblGeoLevel3.Level3ID Level4ID, character, 3 bytes, identifier for fourth level in geographic classificationName, text, 50 bytes maximum, name for the region ("county")CountryCode, character, 2 bytes, ISO country code of the regiontblGazetteer, shared across files, listing of names and the 
							corresponding values in the preceding four tables, used with human data entry. 
								ID, integer, 2 bytes, identifier for the nameName, text, 50 byes maximum, place name (duplicates permitted)Level1ID, character, 1 byte, = tblGeoLevel1.Level1IDLevel2ID, character, 1 byte, = tblGeoLevel2.Level2IDLevel3ID, character, 3 bytes, = tblGeoLevel3.Level3ID Level4ID, character, 3 bytes, = tblGeoLevel4.Level4ID tblLandCoords, shared across files, organized polygon point
							lists by TDWG codes for land areas
								Level1ID, character, 1 byte, = tblGeoLevel1.Level1ID Level2ID, character, 1 byte, = tblGeoLevel2.Level2ID Level3ID, character, 3 bytes, = tblGeoLevel3.Level3ID Level4ID, character, 3 bytes, = tblGeoLevel4.Level4IDPolygon, integer, 4 bytes, 1-based index of polygon list for this code combinationPoint, integer, 4 bytes, 1-based index of point listXlon, float, longitiude coordinate in degreesYlat, float, latitiude coordinate in degreestblSeaCoords, shared across files, organized
							polygon point lists by TDWG codes for oceanic areas
								Level1ID, character, 1 byte, = tblGeoLevel1.Level1ID Level2ID, character, 1 byte, = tblGeoLevel2.Level2ID Level3ID, character, 3 bytes, = tblGeoLevel3.Level3ID Level4ID, character, 3 bytes, = tblGeoLevel4.Level4IDPolygon, integer, 4 bytes, 1-based index of polygon list for this code combinationPoint, integer, 4 bytes, 1-based index of point listXlon, float, longitiude coordinate in degreesYlat, float, latitiude coordinate in degreestblTDWGtoITIS, shared across files, for conversion of the TDWG geo classification
							to the ITIS geo classification.
							
								TDWGcode, text, 8 bytes maximum, TDWG classificationLevel1, character, 1 byte, TDWG classification, = tblGeoLevel1.Level1ID Level2, character, 1 byte, TDWG classification, = tblGeoLevel2.Level2IDLevel3, character, 3 bytes, TDWG classification, = tblGeoLevel3.Level3ID Location, text, 50 bytes maximum, TDWG classificationJurisdiction, text, 50 bytes maximum, ITIS classificationGeographic, text, 50 bytes maximum, ITIS classificationtblTimePeriods, shared across files, geologic time period
							
								TimePeriodID, integer, 2 bytes, identifier for time periodName, text, 20 bytes maximum, name of geologic periodMaxID, integer, 2 bytes, upper limit for values of TimePeriodID contained within this nameListLevel, integer, 2 bytes, level of dropdownlist for users to select time periodtblCollectEvents, information about the date and collector
							
								CollectEventID, integer, 4 bytes, identifier for the collecting eventCollectorName, text, 100 bytes maximum.  To be deleted
									when CollectorID is implemented and linking table to tblPeople is available.Year, integer, 2 bytes, year collecting started. There is a special case of 
									Year = 1000, used to signify that no year is available for the collection event, 
									but month (and perhaps day) are significant to the event.Month, integer, 1 byte, month collecting startedDay, integer, 1 byte, day of month collecting startedDaysToEnd, integer, 2 bytes, additional days in collecting period (usually 0)LastUpdate, smalldatetime, date and time of last updateModifiedBy, integer, 2 bytes, UserID of the signon that made the change |