-- ******************************** -- Core tables -- ******************************** CREATE TABLE `Project` ( `ProjectID` INT(10) unsigned NOT NULL AUTO_INCREMENT, `Name` VARCHAR(255) NOT NULL, `Alias` char(4) NOT NULL, `recruitmentTarget` INT(6) Default NULL, `showSummaryOnLogin` BOOLEAN DEFAULT TRUE, PRIMARY KEY (`ProjectID`), UNIQUE KEY `u_ProjectName` (`Name`) ) ENGINE = InnoDB DEFAULT CHARSET=utf8; INSERT INTO `Project` (Name,Alias) VALUES ('loris','LORI'); CREATE TABLE `cohort` ( `CohortID` int(10) unsigned NOT NULL auto_increment, `title` varchar(255) NOT NULL, `useEDC` boolean, `WindowDifference` enum('optimal', 'battery'), `RecruitmentTarget` int(10) unsigned, PRIMARY KEY (CohortID), UNIQUE KEY `title` (`title`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Stores Cohorts used in Loris'; INSERT INTO cohort (title, useEDC, WindowDifference) VALUES ('Control', false, 'optimal'), ('Experimental', false, 'optimal'); CREATE TABLE `project_cohort_rel` ( `ProjectCohortRelID` int(10) unsigned NOT NULL AUTO_INCREMENT, `ProjectID` int(10) unsigned NOT NULL, `CohortID` int(10) unsigned NOT NULL, PRIMARY KEY (`ProjectCohortRelID`), CONSTRAINT `UK_project_cohort_rel_ProjectID_CohortID` UNIQUE KEY (ProjectID, CohortID), CONSTRAINT `FK_project_cohort_rel_ProjectID` FOREIGN KEY (`ProjectID`) REFERENCES `Project` (`ProjectID`) ON DELETE CASCADE, CONSTRAINT `FK_project_cohort_rel_CohortID` FOREIGN KEY (`CohortID`) REFERENCES `cohort` (`CohortID`) ON DELETE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `psc` ( `CenterID` integer unsigned NOT NULL AUTO_INCREMENT, `Name` varchar(150) NOT NULL DEFAULT '', `PSCArea` varchar(150) DEFAULT NULL, `Address` varchar(150) DEFAULT NULL, `City` varchar(150) DEFAULT NULL, `StateID` tinyint(2) unsigned DEFAULT NULL, `ZIP` varchar(12) DEFAULT NULL, `Phone1` varchar(12) DEFAULT NULL, `Phone2` varchar(12) DEFAULT NULL, `Contact1` varchar(150) DEFAULT NULL, `Contact2` varchar(150) DEFAULT NULL, `Alias` char(4) NOT NULL DEFAULT '', `MRI_alias` varchar(4) NOT NULL DEFAULT '', `Account` varchar(8) DEFAULT NULL, `Study_site` enum('N','Y') DEFAULT 'Y', PRIMARY KEY (`CenterID`), UNIQUE KEY `Name` (`Name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `psc` (Name, Alias, Study_site) VALUES ('Data Coordinating Center','DCC', 'Y'); CREATE TABLE `language` ( `language_id` integer unsigned NOT NULL AUTO_INCREMENT, `language_code` varchar(255) NOT NULL, `language_label` varchar(255) NOT NULL, PRIMARY KEY (`language_id`), UNIQUE KEY (`language_code`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO language (language_code, language_label) VALUES ('en-CA', 'English'); CREATE TABLE `sex` ( `Name` varchar(255) NOT NULL, PRIMARY KEY `Name` (`Name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Stores sex options available for candidates in LORIS'; INSERT INTO sex (Name) VALUES ('Male'), ('Female'), ('Other'); CREATE TABLE `users` ( `ID` int(10) unsigned NOT NULL auto_increment, `UserID` varchar(255) NOT NULL default '', `Password` varchar(255) default NULL, `Real_name` varchar(255) default NULL, `First_name` varchar(255) default NULL, `Last_name` varchar(255) default NULL, `Degree` varchar(255) default NULL, `Position_title` varchar(255) default NULL, `Institution` varchar(255) default NULL, `Department` varchar(255) default NULL, `Address` varchar(255) default NULL, `City` varchar(255) default NULL, `State` varchar(255) default NULL, `Zip_code` varchar(255) default NULL, `Country` varchar(255) default NULL, `Phone` varchar(15) default NULL, `Fax` varchar(255) default NULL, `Email` varchar(255) NOT NULL default '', `Privilege` tinyint(1) NOT NULL default 0, `PSCPI` enum('Y','N') NOT NULL default 'N', `DBAccess` varchar(10) NOT NULL default '', `Active` enum('Y','N') NOT NULL default 'Y', `Password_hash` varchar(255) default NULL, `PasswordChangeRequired` tinyint(1) NOT NULL default 0, `TOTPSecret` binary(64) DEFAULT NULL, `Pending_approval` enum('Y','N') default 'Y', `Doc_Repo_Notifications` enum('Y','N') default 'N', `language_preference` integer unsigned default NULL, `active_from` date default NULL, `active_to` date default NULL, `account_request_date` date default NULL, PRIMARY KEY (`ID`), UNIQUE KEY `Email` (`Email`), UNIQUE KEY `UserID` (`UserID`), CONSTRAINT `FK_users_2` FOREIGN KEY (`language_preference`) REFERENCES `language` (`language_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `users` (ID,UserID,Real_name,First_name,Last_name,Email,Privilege,PSCPI,DBAccess,Active,Pending_approval,PasswordChangeRequired) VALUES (1,'admin','Admin account','Admin','account','admin@example.com',0,'N','','Y','N',0); CREATE TABLE `user_psc_rel` ( `UserID` int(10) unsigned NOT NULL, `CenterID` integer unsigned NOT NULL, PRIMARY KEY (`UserID`,`CenterID`), KEY `FK_user_psc_rel_2` (`CenterID`), CONSTRAINT `FK_user_psc_rel_2` FOREIGN KEY (`CenterID`) REFERENCES `psc` (`CenterID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_user_psc_rel_1` FOREIGN KEY (`UserID`) REFERENCES `users` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO user_psc_rel (UserID, CenterID) SELECT 1, CenterID FROM psc; CREATE TABLE `user_project_rel` ( `UserID` int(10) unsigned NOT NULL, `ProjectID` int(10) unsigned NOT NULL, PRIMARY KEY (`UserID`,`ProjectID`), CONSTRAINT `FK_user_project_rel_UserID` FOREIGN KEY (`UserID`) REFERENCES `users` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_user_project_rel_ProjectID` FOREIGN KEY (`ProjectID`) REFERENCES `Project` (`ProjectID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO user_project_rel (UserID, ProjectID) SELECT 1, ProjectID FROM Project; CREATE TABLE `caveat_options` ( `ID` int(6), `Description` varchar(255), PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `candidate` ( `ID` int(10) unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT, `CandID` int(10) unsigned NOT NULL, `PSCID` varchar(255) NOT NULL DEFAULT '', `ExternalID` varchar(255) DEFAULT NULL, `DoB` date DEFAULT NULL, `DoD` date DEFAULT NULL, `EDC` date DEFAULT NULL, `Sex` varchar(255) DEFAULT NULL, `RegistrationCenterID` integer unsigned NOT NULL, `RegistrationProjectID` int(10) unsigned NOT NULL, `Ethnicity` varchar(255) DEFAULT NULL, `Active` enum('Y','N') NOT NULL DEFAULT 'Y', `Date_active` date DEFAULT NULL, `RegisteredBy` varchar(255) DEFAULT NULL, `UserID` varchar(255) NOT NULL DEFAULT '', `Date_registered` date DEFAULT NULL, `flagged_caveatemptor` enum('true','false') DEFAULT 'false', `flagged_reason` int(6) DEFAULT NULL, `flagged_other` varchar(255) DEFAULT NULL, `flagged_other_status` enum('not_answered') DEFAULT NULL, `Testdate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `Entity_type` enum('Human','Scanner') NOT NULL DEFAULT 'Human', `ProbandSex` varchar(255) DEFAULT NULL, `ProbandDoB` date DEFAULT NULL, UNIQUE KEY `ID` (`ID`), UNIQUE KEY `ExternalID` (`ExternalID`), KEY `FK_candidate_1` (`RegistrationCenterID`), KEY `CandidateActive` (`Active`), KEY `FK_candidate_2_idx` (`flagged_reason`), KEY `PSCID` (`PSCID`), KEY `FK_candidate_sex_1` (`Sex`), KEY `FK_candidate_sex_2` (`ProbandSex`), CONSTRAINT `FK_candidate_1` FOREIGN KEY (`RegistrationCenterID`) REFERENCES `psc` (`CenterID`), CONSTRAINT `FK_candidate_2` FOREIGN KEY (`flagged_reason`) REFERENCES `caveat_options` (`ID`) ON DELETE RESTRICT ON UPDATE CASCADE, CONSTRAINT `FK_candidate_RegistrationProjectID` FOREIGN KEY (`RegistrationProjectID`) REFERENCES `Project` (`ProjectID`) ON UPDATE CASCADE, CONSTRAINT `FK_candidate_sex_1` FOREIGN KEY (`Sex`) REFERENCES `sex` (`Name`) ON DELETE RESTRICT ON UPDATE CASCADE, CONSTRAINT `FK_candidate_sex_2` FOREIGN KEY (`ProbandSex`) REFERENCES `sex` (`Name`) ON DELETE RESTRICT ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `session` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `CandidateID` int(10) unsigned NOT NULL, `CenterID` integer unsigned NOT NULL, `ProjectID` int(10) unsigned NOT NULL, `VisitNo` smallint(5) unsigned DEFAULT NULL, `Visit_label` varchar(255) NOT NULL, `CohortID` int(10) unsigned DEFAULT NULL, `Submitted` enum('Y','N') NOT NULL DEFAULT 'N', `Current_stage` enum('Not Started','Screening','Visit','Approval','Subject','Recycling Bin') NOT NULL DEFAULT 'Not Started', `Date_stage_change` date DEFAULT NULL, `Screening` enum('Pass','Failure','Withdrawal','In Progress') DEFAULT NULL, `Date_screening` date DEFAULT NULL, `Visit` enum('Pass','Failure','Withdrawal','In Progress') DEFAULT NULL, `Date_visit` date DEFAULT NULL, `Date_status_change` date DEFAULT NULL, `Approval` enum('In Progress','Pass','Failure') DEFAULT NULL, `Date_approval` date DEFAULT NULL, `Active` enum('Y','N') NOT NULL DEFAULT 'Y', `Date_active` date DEFAULT NULL, `RegisteredBy` varchar(255) DEFAULT NULL, `UserID` varchar(255) NOT NULL DEFAULT '', `Date_registered` date DEFAULT NULL, `Testdate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `Hardcopy_request` enum('-','N','Y') NOT NULL DEFAULT '-', `BVLQCStatus` enum('Complete') DEFAULT NULL, `BVLQCType` enum('Visual','Hardcopy') DEFAULT NULL, `BVLQCExclusion` enum('Excluded','Not Excluded') DEFAULT NULL, `QCd` enum('Visual','Hardcopy') DEFAULT NULL, `Scan_done` enum('N','Y') DEFAULT NULL, `MRIQCStatus` enum('','Pass','Fail') NOT NULL DEFAULT '', `MRIQCPending` enum('Y','N') NOT NULL DEFAULT 'N', `MRIQCFirstChangeTime` datetime DEFAULT NULL, `MRIQCLastChangeTime` datetime DEFAULT NULL, `MRICaveat` enum('true','false') NOT NULL DEFAULT 'false', `languageID` integer unsigned DEFAULT NULL, PRIMARY KEY (`ID`), KEY `session_candVisit` (`CandidateID`,`VisitNo`), KEY `FK_session_2` (`CenterID`), KEY `SessionCohort` (`CohortID`), KEY `SessionActive` (`Active`), CONSTRAINT `FK_session_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`), CONSTRAINT `FK_session_2` FOREIGN KEY (`CenterID`) REFERENCES `psc` (`CenterID`), CONSTRAINT `FK_session_3` FOREIGN KEY (`CohortID`) REFERENCES `cohort` (`CohortID`), CONSTRAINT `FK_session_4` FOREIGN KEY (`languageID`) REFERENCES `language` (`language_id`), CONSTRAINT `FK_session_ProjectID` FOREIGN KEY (`ProjectID`) REFERENCES `Project` (`ProjectID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Table holding session information'; CREATE TABLE `session_status` ( `ID` int(11) NOT NULL AUTO_INCREMENT, `SessionID` int(10) unsigned NOT NULL, `Name` varchar(64) NOT NULL, `Value` varchar(255) DEFAULT NULL, PRIMARY KEY (`ID`), KEY `session_status_index` (`SessionID`,`Name`), CONSTRAINT `fk_session_status_1` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Used if SupplementalSessionStatus configSettings is true'; CREATE TABLE `test_subgroups` ( `ID` int(11) unsigned NOT NULL auto_increment, `Subgroup_name` varchar(255) default NULL, `group_order` tinyint(4) default NULL, PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO test_subgroups (Subgroup_name) VALUES ('Instruments'),('Imaging'); CREATE TABLE `test_names` ( `ID` int(10) unsigned NOT NULL auto_increment, `Test_name` varchar(255) default NULL, `Full_name` varchar(255) default NULL, `Sub_group` int(11) unsigned NOT NULL, `IsDirectEntry` boolean default NULL, PRIMARY KEY (`ID`), UNIQUE KEY `Test_name` (`Test_name`), KEY `FK_test_names_1` (`Sub_group`), CONSTRAINT `FK_test_names_1` FOREIGN KEY (`Sub_group`) REFERENCES `test_subgroups` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `instrument_subtests` ( `ID` int(11) NOT NULL auto_increment, `Test_name` varchar(255) NOT NULL default '', `Subtest_name` varchar(255) NOT NULL default '', `Description` varchar(255) NOT NULL default '', `Order_number` int(11) NOT NULL default 0, UNIQUE KEY `unique_index` (`Test_name`, `Subtest_name`), PRIMARY KEY (`ID`), KEY `FK_instrument_subtests_1` (`Test_name`), CONSTRAINT `FK_instrument_subtests_1` FOREIGN KEY (`Test_name`) REFERENCES `test_names` (`Test_name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `instrument_data` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `Data` longtext CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL CHECK (json_valid(`Data`)), PRIMARY KEY (`ID`) ); CREATE TABLE `flag` ( `ID` int(10) unsigned NOT NULL auto_increment, `SessionID` int(10) unsigned NOT NULL, `TestID` int(10) unsigned NOT NULL, `CommentID` varchar(255) NOT NULL, `Data_entry` enum('In Progress','Complete') default NULL, `Required_elements_completed` enum('Y','N') NOT NULL default 'N', `Administration` enum('None','Partial','All') default NULL, `Validity` enum('Questionable','Invalid','Valid') default NULL, `Exclusion` enum('Fail','Pass') default NULL, `Testdate` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP, `DataID` int(10) unsigned default NULL, PRIMARY KEY (`CommentID`), KEY `flag_ID` (`ID`), KEY `flag_SessionID` (`SessionID`), KEY `flag_Exclusion` (`Exclusion`), KEY `flag_Data_entry` (`Data_entry`), KEY `flag_Validity` (`Validity`), KEY `flag_Administration` (`Administration`), CONSTRAINT `FK_flag_1` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_flag_3` FOREIGN KEY (`DataID`) REFERENCES `instrument_data` (`ID`), CONSTRAINT `FK_ibfk_1` FOREIGN KEY (`TestID`) REFERENCES `test_names` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `flag_editors` ( `userID` int(10) unsigned NOT NULL, `CommentID` VARCHAR(255) NOT NULL, `editDate` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP, PRIMARY KEY (`userID`,`CommentID`), KEY `FK_flag_editors_2` (`CommentID`), CONSTRAINT `FK_flag_editors_2` FOREIGN KEY (`CommentID`) REFERENCES `flag` (`CommentID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_flag_editors_1` FOREIGN KEY (`userID`) REFERENCES `users` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `history` ( `id` int(11) NOT NULL auto_increment, `tbl` varchar(255) NOT NULL default '', `col` varchar(255) NOT NULL default '', `old` text, `new` text, `primaryCols` text, `primaryVals` text, `changeDate` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP, `userID` varchar(255) NOT NULL default '', `type` char(1), PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='This table keeps track of ongoing changes in the database. '; CREATE TABLE `test_battery` ( `ID` int(10) unsigned NOT NULL auto_increment, `Test_name` varchar(255) NOT NULL default '', `AgeMinDays` int(10) unsigned default NULL, `AgeMaxDays` int(10) unsigned default NULL, `Active` enum('Y','N') NOT NULL default 'Y', `Stage` varchar(255) default NULL, `CohortID` int(11) default NULL, `Visit_label` varchar(255) default NULL, `CenterID` int(11) default NULL, `firstVisit` enum('Y','N') default NULL, `instr_order` tinyint(4) default NULL, `DoubleDataEntryEnabled` enum('Y','N') NOT NULL default 'N', PRIMARY KEY (`ID`), KEY `age_test` (`AgeMinDays`,`AgeMaxDays`,`Test_name`), KEY `FK_test_battery_1` (`Test_name`), CONSTRAINT `FK_test_battery_1` FOREIGN KEY (`Test_name`) REFERENCES `test_names` (`Test_name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `Visit_Windows` ( `ID` int(11) NOT NULL AUTO_INCREMENT, `Visit_label` varchar(255) DEFAULT NULL, `WindowMinDays` int(11) DEFAULT NULL, `WindowMaxDays` int(11) DEFAULT NULL, `OptimumMinDays` int(11) DEFAULT NULL, `OptimumMaxDays` int(11) DEFAULT NULL, `WindowMidpointDays` int(11) DEFAULT NULL, PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- tarchive tables -- ******************************** CREATE TABLE `tarchive` ( `DicomArchiveID` varchar(255) NOT NULL default '', `PatientID` varchar(255) NOT NULL default '', `PatientName` varchar(255) NOT NULL default '', `PatientDoB` date default NULL, `PatientSex` varchar(255) default NULL, `neurodbCenterName` varchar(255) default NULL, `CenterName` varchar(255) NOT NULL default '', `LastUpdate` datetime default NULL, `DateAcquired` date default NULL, `DateFirstArchived` datetime default NULL, `DateLastArchived` datetime default NULL, `AcquisitionCount` int(11) NOT NULL default 0, `NonDicomFileCount` int(11) NOT NULL default 0, `DicomFileCount` int(11) NOT NULL default 0, `md5sumDicomOnly` varchar(255) default NULL, `md5sumArchive` varchar(255) default NULL, `CreatingUser` varchar(255) NOT NULL default '', `sumTypeVersion` tinyint(4) NOT NULL default 0, `tarTypeVersion` tinyint(4) default NULL, `SourceLocation` varchar(255) NOT NULL default '', `ArchiveLocation` varchar(255) default NULL, `ScannerManufacturer` varchar(255) NOT NULL default '', `ScannerModel` varchar(255) NOT NULL default '', `ScannerSerialNumber` varchar(255) NOT NULL default '', `ScannerSoftwareVersion` varchar(255) NOT NULL default '', `SessionID` int(10) unsigned default NULL, `uploadAttempt` tinyint(4) NOT NULL default 0, `CreateInfo` text, `AcquisitionMetadata` longtext NOT NULL, `TarchiveID` int(11) NOT NULL auto_increment, `DateSent` datetime DEFAULT NULL, `PendingTransfer` tinyint(1) NOT NULL DEFAULT 0, PRIMARY KEY (`TarchiveID`), KEY `SessionID` (`SessionID`), CONSTRAINT `FK_tarchive_sessionID` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `tarchive_series` ( `TarchiveSeriesID` int(11) NOT NULL auto_increment, `TarchiveID` int(11) NOT NULL, `SeriesNumber` int(11) NOT NULL default 0, `SeriesDescription` varchar(255) default NULL, `SequenceName` varchar(255) default NULL, `EchoTime` double default NULL, `RepetitionTime` double default NULL, `InversionTime` double default NULL, `SliceThickness` double default NULL, `PhaseEncoding` varchar(255) default NULL, `NumberOfFiles` int(11) NOT NULL default 0, `SeriesUID` varchar(255) default NULL, `Modality` ENUM ('MR', 'PT') default NULL, PRIMARY KEY (`TarchiveSeriesID`), KEY `TarchiveID` (`TarchiveID`), CONSTRAINT `tarchive_series_ibfk_1` FOREIGN KEY (`TarchiveID`) REFERENCES `tarchive` (`TarchiveID`) ON DELETE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `tarchive_files` ( `TarchiveFileID` int(11) NOT NULL auto_increment, `TarchiveID` int(11) NOT NULL, `TarchiveSeriesID` INT(11) DEFAULT NULL, `SeriesNumber` int(11) default NULL, `FileNumber` int(11) default NULL, `EchoNumber` int(11) default NULL, `SeriesDescription` varchar(255) default NULL, `Md5Sum` varchar(255) NOT NULL, `FileName` varchar(255) NOT NULL, PRIMARY KEY (`TarchiveFileID`), KEY `TarchiveID` (`TarchiveID`), KEY `TarchiveSeriesID` (`TarchiveSeriesID`), CONSTRAINT `tarchive_files_ibfk_1` FOREIGN KEY (`TarchiveID`) REFERENCES `tarchive` (`TarchiveID`) ON DELETE CASCADE, CONSTRAINT `tarchive_files_TarchiveSeriesID_fk` FOREIGN KEY (`TarchiveSeriesID`) REFERENCES `tarchive_series` (`TarchiveSeriesID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- HRRT PET archive tables -- ******************************** CREATE TABLE `hrrt_archive` ( `HrrtArchiveID` INT(11) NOT NULL AUTO_INCREMENT, `SessionID` INT(10) unsigned DEFAULT NULL, `EcatFileCount` INT(11) NOT NULL DEFAULT 0, `NonEcatFileCount` INT(11) NOT NULL DEFAULT 0, `DateAcquired` DATE DEFAULT NULL, `DateArchived` DATETIME DEFAULT NULL, `PatientName` VARCHAR(50) NOT NULL DEFAULT '', `CenterName` VARCHAR(50) NOT NULL DEFAULT '', `CreatingUser` VARCHAR(50) NOT NULL DEFAULT '', `Blake2bArchive` VARCHAR(255) DEFAULT NULL, `ArchiveLocation` VARCHAR(255) DEFAULT NULL, PRIMARY KEY (`HrrtArchiveID`), KEY `patNam` (`CenterName`(10),`PatientName`(30)), KEY `FK_hrrt_archive_sessionID` (`SessionID`), CONSTRAINT `FK_hrrt_archive_sessionID` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `hrrt_archive_files` ( `HrrtArchiveFileID` INT(11) NOT NULL AUTO_INCREMENT, `HrrtArchiveID` INT(11) NOT NULL, `Blake2bHash` VARCHAR(255) NOT NULL, `FileName` VARCHAR(255) NOT NULL, PRIMARY KEY (`HrrtArchiveFileID`), KEY `HrrtArchiveID` (`HrrtArchiveID`), CONSTRAINT `hrrt_archive_files_ibfk_1` FOREIGN KEY (`HrrtArchiveID`) REFERENCES `hrrt_archive` (`HrrtArchiveID`) ON DELETE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- Imaging tables -- ******************************** CREATE TABLE `ImagingFileTypes` ( `type` varchar(12) NOT NULL PRIMARY KEY, `description` varchar(255) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `ImagingFileTypes` (type, description) VALUES ('mnc', 'MINC file'), ('obj', 'MNI BIC imaging format for a surface'), ('xfm', 'MNI BIC linear transformation matrix file'), ('vertstat', 'MNI BIC imaging format for a field on a surface (e.g. cortical thickness)'), ('xml', 'XML file'), ('txt', 'text file'), ('nii', 'NIfTI file'), ('nrrd', 'NRRD file format (used by DTIPrep)'), ('grid_0', 'MNI BIC non-linear field for non-linear transformation'), ('json', 'JSON file'), ('readme', 'README file'), ('tsv', 'Tab separated values (TSV) file'), ('bval', 'NIfTI DWI file with b-values'), ('bvec', 'NIfTI DWI file with b-vectors'); CREATE TABLE `mri_processing_protocol` ( `ProcessProtocolID` int(11) unsigned NOT NULL AUTO_INCREMENT, `ProtocolFile` varchar(255) NOT NULL DEFAULT '', `FileType` varchar(12) DEFAULT NULL, `Tool` varchar(255) NOT NULL DEFAULT '', `InsertTime` int(10) unsigned NOT NULL DEFAULT 0, `md5sum` varchar(32) DEFAULT NULL, PRIMARY KEY (`ProcessProtocolID`), CONSTRAINT `FK_mri_processing_protocol_FileTypes` FOREIGN KEY (`FileType`) REFERENCES `ImagingFileTypes`(`type`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_scanner` ( `ID` int(11) unsigned NOT NULL auto_increment, `Manufacturer` varchar(255) default NULL, `Model` varchar(255) default NULL, `Serial_number` varchar(255) default NULL, `Software` varchar(255) default NULL, `CandidateID` int(10) unsigned DEFAULT NULL, PRIMARY KEY (`ID`), KEY `FK_mri_scanner_1` (`CandidateID`), CONSTRAINT `FK_mri_scanner_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; SET @OLD_SQL_MODE=@@SQL_MODE; SET SQL_MODE='NO_AUTO_VALUE_ON_ZERO'; INSERT INTO `mri_scanner` (ID) VALUES (0); SET SQL_MODE=@OLD_SQL_MODE; CREATE TABLE `mri_scan_type` ( `MriScanTypeID` int(11) unsigned NOT NULL auto_increment, `MriScanTypeName` VARCHAR(255) NOT NULL, PRIMARY KEY (`MriScanTypeID`), CONSTRAINT `UK_mri_scan_type_name` UNIQUE KEY `MriScanTypeName` (`MriScanTypeName`) ) ENGINE=InnoDB AUTO_INCREMENT=1001 DEFAULT CHARSET=utf8; INSERT INTO `mri_scan_type` VALUES (40,'fMRI'), (41,'flair'), (44,'t1'), (45,'t2'), (46,'pd'), (47,'mrs'), (48,'dti'), (49,'t1relx'), (50,'dct2e1'), (51,'dct2e2'), (52,'scout'), (53,'tal_msk'), (54,'cocosco_cls'), (55,'clean_cls'), (56,'em_cls'), (57,'seg'), (58,'white_matter'), (59,'gray_matter'), (60,'csf_matter'), (61,'nlr_masked'), (62,'pve'), (999,'unknown'), (1000,'NA'); CREATE TABLE `files` ( `FileID` int(10) unsigned NOT NULL auto_increment, `SessionID` int(10) unsigned NOT NULL, `File` varchar(255) NOT NULL default '', `SeriesUID` varchar(64) DEFAULT NULL, `EchoTime` double DEFAULT NULL, `PhaseEncodingDirection` VARCHAR(3) DEFAULT NULL, `EchoNumber` VARCHAR(20) DEFAULT NULL, `CoordinateSpace` varchar(255) default NULL, `OutputType` varchar(255) NOT NULL default '', `MriScanTypeID` int(10) unsigned default NULL, `FileType` varchar(12) default NULL, `InsertedByUserID` varchar(255) NOT NULL default '', `InsertTime` int(10) unsigned NOT NULL default 0, `SourcePipeline` varchar(255), `PipelineDate` date, `SourceFileID` int(10) unsigned, `ProcessProtocolID` int(11) unsigned, `Caveat` tinyint(1) default NULL, `TarchiveSource` int(11) default NULL, `HrrtArchiveID` int(11) default NULL, `ScannerID` int(10) unsigned default NULL, `AcqOrderPerModality` int(11) default NULL, `AcquisitionDate` date default NULL, PRIMARY KEY (`FileID`), KEY `file` (`File`), KEY `sessionid` (`SessionID`), KEY `outputtype` (`OutputType`), KEY `filetype_outputtype` (`FileType`,`OutputType`), KEY `ScanIndex` (`MriScanTypeID`,`SessionID`), KEY `scannerid` (`ScannerID`), KEY `tarchivesource` (`TarchiveSource`), KEY `FK_files_HrrtArchiveID_1` (`HrrtArchiveID`), CONSTRAINT `FK_files_2` FOREIGN KEY (`MriScanTypeID`) REFERENCES `mri_scan_type` (`MriScanTypeID`), CONSTRAINT `FK_files_1` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`), CONSTRAINT `FK_files_3` FOREIGN KEY (`SourceFileID`) REFERENCES `files` (`FileID`), CONSTRAINT `FK_files_4` FOREIGN KEY (`ProcessProtocolID`) REFERENCES `mri_processing_protocol` (`ProcessProtocolID`), CONSTRAINT `FK_files_FileTypes` FOREIGN KEY (`FileType`) REFERENCES `ImagingFileTypes`(`type`), CONSTRAINT `FK_files_scannerID` FOREIGN KEY (`ScannerID`) REFERENCES `mri_scanner` (`ID`), CONSTRAINT `FK_files_TarchiveID` FOREIGN KEY (`TarchiveSource`) REFERENCES `tarchive` (`TarchiveID`), CONSTRAINT `FK_files_HrrtArchiveID` FOREIGN KEY (`HrrtArchiveID`) REFERENCES `hrrt_archive` (`HrrtArchiveID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `files_intermediary` ( `IntermedID` int(11) NOT NULL AUTO_INCREMENT, `Output_FileID` int(10) unsigned NOT NULL, `Input_FileID` int(10) unsigned NOT NULL, `Tool` varchar(255) NOT NULL, PRIMARY KEY (`IntermedID`), KEY `FK_files_intermediary_1` (`Output_FileID`), KEY `FK_files_intermediary_2` (`Input_FileID`), CONSTRAINT `FK_files_intermediary_1` FOREIGN KEY (`Output_FileID`) REFERENCES `files` (`FileID`), CONSTRAINT `FK_files_intermediary_2` FOREIGN KEY (`Input_FileID`) REFERENCES `files` (`FileID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `files_qcstatus` ( `FileQCID` int(11) auto_increment, `FileID` int(10) UNSIGNED UNIQUE NULL, `SeriesUID` varchar(64) DEFAULT NULL, `EchoTime` double DEFAULT NULL, `PhaseEncodingDirection` VARCHAR(3) DEFAULT NULL, `EchoNumber` VARCHAR(20) DEFAULT NULL, `QCStatus` enum('Pass', 'Fail'), `QCFirstChangeTime` int(10) unsigned, `QCLastChangeTime` int(10) unsigned, `Selected` enum('true', 'false') DEFAULT NULL, PRIMARY KEY (`FileQCID`), KEY (`FileID`), CONSTRAINT `FK_filesqcstatus_FileID` FOREIGN KEY (`FileID`) REFERENCES `files` (`FileID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_protocol_group` ( `MriProtocolGroupID` INT(4) UNSIGNED NOT NULL AUTO_INCREMENT, `Name` VARCHAR(255) NOT NULL UNIQUE, PRIMARY KEY (`MriProtocolGroupID`) ) ENGINE = InnoDB DEFAULT CHARSET=utf8mb4; INSERT INTO `mri_protocol_group` (`Name`) VALUES('Default MRI protocol group'); CREATE TABLE `mri_protocol` ( `ID` int(11) unsigned NOT NULL auto_increment, `CenterID` integer unsigned DEFAULT NULL, `ScannerID` int(10) unsigned DEFAULT NULL, `MriScanTypeID` int(10) unsigned NOT NULL, `TR_min` DECIMAL(10,4) DEFAULT NULL, `TR_max` DECIMAL(10,4) DEFAULT NULL, `TE_min` DECIMAL(10,4) DEFAULT NULL, `TE_max` DECIMAL(10,4) DEFAULT NULL, `TI_min` DECIMAL(10,4) DEFAULT NULL, `TI_max` DECIMAL(10,4) DEFAULT NULL, `slice_thickness_min` DECIMAL(9,4) DEFAULT NULL, `slice_thickness_max` DECIMAL(9,4) DEFAULT NULL, `xspace_min` int(4) DEFAULT NULL, `xspace_max` int(4) DEFAULT NULL, `yspace_min` int(4) DEFAULT NULL, `yspace_max` int(4) DEFAULT NULL, `zspace_min` int(4) DEFAULT NULL, `zspace_max` int(4) DEFAULT NULL, `xstep_min` DECIMAL(9,4) DEFAULT NULL, `xstep_max` DECIMAL(9,4) DEFAULT NULL, `ystep_min` DECIMAL(9,4) DEFAULT NULL, `ystep_max` DECIMAL(9,4) DEFAULT NULL, `zstep_min` DECIMAL(9,4) DEFAULT NULL, `zstep_max` DECIMAL(9,4) DEFAULT NULL, `time_min` int(4) DEFAULT NULL, `time_max` int(4) DEFAULT NULL, `image_type` varchar(255) default NULL, `series_description_regex` varchar(255) default NULL, `PhaseEncodingDirection` VARCHAR(3) DEFAULT NULL, `EchoNumber` VARCHAR(20) DEFAULT NULL, `MriProtocolGroupID` INT(4) UNSIGNED NOT NULL, PRIMARY KEY (`ID`), KEY `FK_mri_protocol_1` (`ScannerID`), CONSTRAINT `FK_mri_protocol_1` FOREIGN KEY (`ScannerID`) REFERENCES `mri_scanner` (`ID`), CONSTRAINT `FK_mri_protocol_2` FOREIGN KEY (`CenterID`) REFERENCES `psc` (`CenterID`), CONSTRAINT `FK_mri_protocol_scan_type` FOREIGN KEY (`MriScanTypeID`) REFERENCES `mri_scan_type` (`MriScanTypeID`), CONSTRAINT `FK_mri_protocol_group_ID_1` FOREIGN KEY (`MriProtocolGroupID`) REFERENCES `mri_protocol_group` (`MriProtocolGroupID`) ) ENGINE=InnoDB AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8; INSERT INTO mri_protocol (CenterID,MriScanTypeID,TR_min,TR_max,TE_min, TE_max,time_min,time_max,MriProtocolGroupID) VALUES (NULL,48,8000,14000,80,130,0,200,(SELECT MriProtocolGroupID FROM mri_protocol_group WHERE Name='Default MRI protocol group')), (NULL,40,1900,2700,10,30,0,500,(SELECT MriProtocolGroupID FROM mri_protocol_group WHERE Name='Default MRI protocol group')), (NULL,44,2000,2500,2,5,NULL,NULL,(SELECT MriProtocolGroupID FROM mri_protocol_group WHERE Name='Default MRI protocol group')), (NULL,45,3000,9000,100,550,NULL,NULL,(SELECT MriProtocolGroupID FROM mri_protocol_group WHERE Name='Default MRI protocol group')); CREATE TABLE `mri_protocol_group_target` ( `MriProtocolGroupTargetID` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT, `MriProtocolGroupID` INT(4) UNSIGNED NOT NULL, `ProjectID` INT(10) UNSIGNED DEFAULT NULL, `CohortID` INT(10) UNSIGNED DEFAULT NULL, `Visit_label` VARCHAR(255) DEFAULT NULL, PRIMARY KEY (`MriProtocolGroupTargetID`), CONSTRAINT `FK_mri_protocol_group_target_1` FOREIGN KEY (`MriProtocolGroupID`) REFERENCES `mri_protocol_group` (`MriProtocolGroupID`), CONSTRAINT `FK_mri_protocol_group_target_2` FOREIGN KEY (`ProjectID`) REFERENCES `Project` (`ProjectID`), CONSTRAINT `FK_mri_protocol_group_target_3` FOREIGN KEY (`CohortID`) REFERENCES `cohort` (`CohortID`), CONSTRAINT `UK_mri_protocol_group_target` UNIQUE (`ProjectID`, `CohortID`, `Visit_label`) ) ENGINE = InnoDB DEFAULT CHARSET=utf8mb4; INSERT INTO `mri_protocol_group_target` (`MriProtocolGroupID`, `ProjectID`, `CohortID`, `Visit_label`) VALUES((SELECT MriProtocolGroupID FROM mri_protocol_group WHERE Name='Default MRI protocol group'), NULL, NULL, NULL); CREATE TABLE `mri_upload` ( `UploadID` int(10) unsigned NOT NULL AUTO_INCREMENT, `UploadedBy` varchar(255) NOT NULL DEFAULT '', `UploadDate` DateTime DEFAULT NULL, `UploadLocation` varchar(255) NOT NULL DEFAULT '', `DecompressedLocation` varchar(255) NOT NULL DEFAULT '', `InsertionComplete` tinyint(1) NOT NULL DEFAULT 0, `Inserting` tinyint(1) DEFAULT NULL, `PatientName` varchar(255) NOT NULL DEFAULT '', `number_of_mincInserted` int(11) DEFAULT NULL, `number_of_mincCreated` int(11) DEFAULT NULL, `TarchiveID` int(11) DEFAULT NULL, `SessionID` int(10) unsigned DEFAULT NULL, `IsCandidateInfoValidated` tinyint(1) DEFAULT NULL, `IsTarchiveValidated` tinyint(1) NOT NULL DEFAULT 0, `IsPhantom` enum('N','Y') NOT NULL DEFAULT 'N', PRIMARY KEY (`UploadID`), KEY (`SessionID`), KEY (`TarchiveID`), CONSTRAINT `FK_mriupload_SessionID` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`), CONSTRAINT `FK_mriupload_TarchiveID` FOREIGN KEY (`TarchiveID`) REFERENCES `tarchive` (`TarchiveID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_upload_rel` ( `UploadRelID` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT, `UploadID` INT(10) UNSIGNED NOT NULL, `HrrtArchiveID` INT(11) DEFAULT NULL, PRIMARY KEY (`UploadRelID`), KEY `FK_mriuploadrel_UploadID` (`UploadID`), KEY `FK_mriuploadrel_HrrtArchiveID` (`HrrtArchiveID`), CONSTRAINT `FK_mriuploadrel_UploadID` FOREIGN KEY (`UploadID`) REFERENCES `mri_upload` (`UploadID`), CONSTRAINT `FK_mriuploadrel_HrrtArchiveID` FOREIGN KEY (`HrrtArchiveID`) REFERENCES `hrrt_archive` (`HrrtArchiveID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_protocol_checks_group` ( `MriProtocolChecksGroupID` INT(4) UNSIGNED NOT NULL AUTO_INCREMENT, `Name` VARCHAR(255) NOT NULL UNIQUE, PRIMARY KEY (`MriProtocolChecksGroupID`) ) ENGINE = InnoDB DEFAULT CHARSET=utf8mb4; INSERT INTO `mri_protocol_checks_group` (`Name`) VALUES('Default MRI protocol checks group'); CREATE TABLE `mri_protocol_checks` ( `ID` int(11) NOT NULL AUTO_INCREMENT, `MriScanTypeID` int(11) unsigned DEFAULT NULL, `Severity` enum('warning','exclude') DEFAULT NULL, `Header` varchar(255) DEFAULT NULL, `ValidMin` decimal(10,4) DEFAULT NULL, `ValidMax` decimal(10,4) DEFAULT NULL, `ValidRegex` varchar(255) DEFAULT NULL, `MriProtocolChecksGroupID` INT(4) UNSIGNED NOT NULL, PRIMARY KEY (`ID`), KEY (`MriScanTypeID`), CONSTRAINT `FK_mri_protocol_checks_scan_type` FOREIGN KEY (`MriScanTypeID`) REFERENCES `mri_scan_type` (`MriScanTypeID`), CONSTRAINT `FK_mri_protocol_checks_group_ID_1` FOREIGN KEY (`MriProtocolChecksGroupID`) REFERENCES `mri_protocol_checks_group` (`MriProtocolChecksGroupID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_protocol_checks_group_target` ( `MriProtocolChecksGroupTargetID` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT, `MriProtocolChecksGroupID` INT(4) UNSIGNED NOT NULL, `ProjectID` INT(10) UNSIGNED DEFAULT NULL, `CohortID` INT(10) UNSIGNED DEFAULT NULL, `Visit_label` VARCHAR(255) DEFAULT NULL, PRIMARY KEY(`MriProtocolChecksGroupTargetID`), CONSTRAINT `FK_mri_protocol_checks_group_target_1` FOREIGN KEY (`MriProtocolChecksGroupID`) REFERENCES `mri_protocol_checks_group` (`MriProtocolChecksGroupID`), CONSTRAINT `FK_mri_protocol_checks_group_target_2` FOREIGN KEY (`ProjectID`) REFERENCES `Project` (`ProjectID`), CONSTRAINT `FK_mri_protocol_checks_group_target_3` FOREIGN KEY (`CohortID`) REFERENCES `cohort` (`CohortID`) ) ENGINE = InnoDB DEFAULT CHARSET=utf8mb4; INSERT INTO `mri_protocol_checks_group_target` (`MriProtocolChecksGroupID`, `ProjectID`, `CohortID`, `Visit_label`) VALUES((SELECT MriProtocolChecksGroupID FROM mri_protocol_checks_group WHERE Name='Default MRI protocol checks group'), NULL, NULL, NULL); -- ******************************** -- BIDS tables -- ******************************** CREATE TABLE `bids_category` ( `BIDSCategoryID` int(3) UNSIGNED NOT NULL AUTO_INCREMENT, `BIDSCategoryName` varchar(10) NOT NULL UNIQUE, PRIMARY KEY (`BIDSCategoryID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `bids_category` (BIDSCategoryName) VALUES ('anat'), ('func'), ('dwi'), ('fmap'); CREATE TABLE `bids_scan_type_subcategory` ( `BIDSScanTypeSubCategoryID` int(3) UNSIGNED NOT NULL AUTO_INCREMENT, `BIDSScanTypeSubCategory` varchar(100) NOT NULL UNIQUE, PRIMARY KEY (`BIDSScanTypeSubCategoryID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `bids_scan_type_subcategory` (BIDSScanTypeSubCategory) VALUES ('task-rest'); CREATE TABLE `bids_scan_type` ( `BIDSScanTypeID` int(3) UNSIGNED NOT NULL AUTO_INCREMENT, `BIDSScanType` varchar(100) NOT NULL UNIQUE, PRIMARY KEY (`BIDSScanTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `bids_scan_type` (BIDSScanType) VALUES ('bold'), ('FLAIR'), ('T1w'), ('T2w'), ('dwi'); CREATE TABLE `bids_phase_encoding_direction` ( `BIDSPhaseEncodingDirectionID` int(3) unsigned NOT NULL AUTO_INCREMENT, `BIDSPhaseEncodingDirectionName` varchar(3) NOT NULL, PRIMARY KEY (`BIDSPhaseEncodingDirectionID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO bids_phase_encoding_direction (BIDSPhaseEncodingDirectionName) VALUES ('i'), ('i-'), ('j'), ('j-'), ('k'), ('k-'); CREATE TABLE `bids_mri_scan_type_rel` ( `MRIScanTypeID` int(10) UNSIGNED NOT NULL, `BIDSCategoryID` int(3) UNSIGNED DEFAULT NULL, `BIDSScanTypeSubCategoryID` int(3) UNSIGNED DEFAULT NULL, `BIDSScanTypeID` int(3) UNSIGNED DEFAULT NULL, `BIDSEchoNumber` int(3) UNSIGNED DEFAULT NULL, `BIDSPhaseEncodingDirectionID` int(3) UNSIGNED DEFAULT NULL, PRIMARY KEY (`MRIScanTypeID`), KEY `FK_bids_mri_scan_type_rel` (`MRIScanTypeID`), CONSTRAINT `FK_bids_mri_scan_type_rel` FOREIGN KEY (`MRIScanTypeID`) REFERENCES `mri_scan_type` (`MriScanTypeID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_bids_category` FOREIGN KEY (`BIDSCategoryID`) REFERENCES `bids_category`(`BIDSCategoryID`), CONSTRAINT `FK_bids_scan_type_subcategory` FOREIGN KEY (`BIDSScanTypeSubCategoryID`) REFERENCES `bids_scan_type_subcategory` (`BIDSScanTypeSubCategoryID`), CONSTRAINT `FK_bids_scan_type` FOREIGN KEY (`BIDSScanTypeID`) REFERENCES `bids_scan_type` (`BIDSScanTypeID`), CONSTRAINT `FK_bids_phase_encoding_direction` FOREIGN KEY (`BIDSPhaseEncodingDirectionID`) REFERENCES `bids_phase_encoding_direction` (`BIDSPhaseEncodingDirectionID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- Default schema scan types; make some of them named in a BIDS compliant manner INSERT INTO bids_mri_scan_type_rel (MRIScanTypeID, BIDSCategoryID, BIDSScanTypeSubCategoryID, BIDSScanTypeID, BIDSEchoNumber) VALUES ( (SELECT MriScanTypeID FROM mri_scan_type WHERE MriScanTypeName = 'flair'), (SELECT BIDSCategoryID FROM bids_category WHERE BIDSCategoryName='anat'), NULL, (SELECT BIDSScanTypeID FROM bids_scan_type WHERE BIDSSCanType='FLAIR'), NULL ), ( (SELECT MriScanTypeID FROM mri_scan_type WHERE MriScanTypeName = 'fMRI'), (SELECT BIDSCategoryID FROM bids_category WHERE BIDSCategoryName='func'), (SELECT BIDSScanTypeSubCategoryID FROM bids_scan_type_subcategory WHERE BIDSScanTypeSubCategory='task-rest'), (SELECT BIDSScanTypeID FROM bids_scan_type WHERE BIDSSCanType='bold'), NULL ), ( (SELECT MriScanTypeID FROM mri_scan_type WHERE MriScanTypeName = 't1'), (SELECT BIDSCategoryID FROM bids_category WHERE BIDSCategoryName='anat'), NULL, (SELECT BIDSScanTypeID FROM bids_scan_type WHERE BIDSSCanType='T1w'), NULL ), ( (SELECT MriScanTypeID FROM mri_scan_type WHERE MriScanTypeName = 't2'), (SELECT BIDSCategoryID FROM bids_category WHERE BIDSCategoryName='anat'), NULL, (SELECT BIDSScanTypeID FROM bids_scan_type WHERE BIDSSCanType='T2w'), NULL ), ( (SELECT MriScanTypeID FROM mri_scan_type WHERE MriScanTypeName = 'dti'), (SELECT BIDSCategoryID FROM bids_category WHERE BIDSCategoryName='dwi'), NULL, (SELECT BIDSScanTypeID FROM bids_scan_type WHERE BIDSSCanType='dwi'), NULL ); CREATE TABLE `bids_export_file_level_category` ( `BIDSExportFileLevelCategoryID` int(10) unsigned NOT NULL AUTO_INCREMENT, `BIDSExportFileLevelCategoryName` varchar(12) NOT NULL, PRIMARY KEY (`BIDSExportFileLevelCategoryID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO bids_export_file_level_category (BIDSExportFileLevelCategoryName) VALUES ('study'), ('image'), ('session'); CREATE TABLE `bids_export_non_imaging_file_category` ( `BIDSNonImagingFileCategoryID` int(10) unsigned NOT NULL AUTO_INCREMENT, `BIDSNonImagingFileCategoryName` varchar(40) NOT NULL, PRIMARY KEY (`BIDSNonImagingFileCategoryID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO bids_export_non_imaging_file_category (BIDSNonImagingFileCategoryName) VALUES ('dataset_description'), ('README'), ('bids-validator-config'), ('participants_list_file'), ('session_list_of_scans'); CREATE TABLE `bids_export_files` ( `BIDSExportedFileID` int(10) unsigned NOT NULL AUTO_INCREMENT, `BIDSExportFileLevelCategoryID` int(10) unsigned NOT NULL, `FileID` int(10) unsigned DEFAULT NULL, `SessionID` int(10) unsigned DEFAULT NULL, `BIDSNonImagingFileCategoryID` int(10) unsigned DEFAULT NULL, `BIDSCategoryID` int(3) unsigned DEFAULT NULL, `FileType` varchar(12) NOT NULL, `FilePath` varchar(255) NOT NULL, PRIMARY KEY (`BIDSExportedFileID`), CONSTRAINT `FK_bef_BIDSExportFileLevelID` FOREIGN KEY (`BIDSExportFileLevelCategoryID`) REFERENCES `bids_export_file_level_category` (`BIDSExportFileLevelCategoryID`), CONSTRAINT `FK_bef_FileID` FOREIGN KEY (`FileID`) REFERENCES `files` (`FileID`), CONSTRAINT `FK_bef_SessionID` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`), CONSTRAINT `FK_bef_BIDSNonImagingFileCategoryID` FOREIGN KEY (`BIDSNonImagingFileCategoryID`) REFERENCES `bids_export_non_imaging_file_category` (`BIDSNonImagingFileCategoryID`), CONSTRAINT `FK_bef_ModalityType` FOREIGN KEY (`BIDSCategoryID`) REFERENCES `bids_category` (`BIDSCategoryID`), CONSTRAINT `FK_bef_FileType` FOREIGN KEY (`FileType`) REFERENCES `ImagingFileTypes` (`type`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- MRI violations tables -- ******************************** CREATE TABLE `MRICandidateErrors` ( `ID` int(11) NOT NULL AUTO_INCREMENT, `TimeRun` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `SeriesUID` varchar(64) DEFAULT NULL, `TarchiveID` int(11) DEFAULT NULL, `MincFile` varchar(255) DEFAULT NULL, `PatientName` varchar(255) DEFAULT NULL, `Reason` varchar(255) DEFAULT NULL, `EchoTime` double DEFAULT NULL, `PhaseEncodingDirection` VARCHAR(3) DEFAULT NULL, `EchoNumber` VARCHAR(20) DEFAULT NULL, PRIMARY KEY (`ID`), CONSTRAINT `FK_tarchive_MRICandidateError_1` FOREIGN KEY (`TarchiveID`) REFERENCES `tarchive` (`TarchiveID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_violations_log` ( `LogID` int(11) NOT NULL AUTO_INCREMENT, `TimeRun` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `SeriesUID` varchar(64) DEFAULT NULL, `TarchiveID` int(11) DEFAULT NULL, `MincFile` varchar(255) DEFAULT NULL, `PatientName` varchar(255) DEFAULT NULL, `CandidateID` int(10) unsigned DEFAULT NULL, `Visit_label` varchar(255) DEFAULT NULL, `CheckID` int(11) DEFAULT NULL, `MriScanTypeID` int(11) unsigned DEFAULT NULL, `Severity` enum('warning','exclude') DEFAULT NULL, `Header` varchar(255) DEFAULT NULL, `Value` varchar(255) DEFAULT NULL, `ValidRange` varchar(255) DEFAULT NULL, `ValidRegex` varchar(255) DEFAULT NULL, `EchoTime` double DEFAULT NULL, `PhaseEncodingDirection` VARCHAR(3) DEFAULT NULL, `EchoNumber` VARCHAR(20) DEFAULT NULL, `MriProtocolChecksGroupID` INT(4) UNSIGNED DEFAULT NULL, PRIMARY KEY (`LogID`), CONSTRAINT `FK_tarchive_mriViolationsLog_1` FOREIGN KEY (`TarchiveID`) REFERENCES `tarchive` (`TarchiveID`), CONSTRAINT `FK_mri_violations_log_scan_type` FOREIGN KEY (`MriScanTypeID`) REFERENCES `mri_scan_type` (`MriScanTypeID`), CONSTRAINT `FK_mri_checks_group_1` FOREIGN KEY (`MriProtocolChecksGroupID`) REFERENCES `mri_protocol_checks_group` (`MriProtocolChecksGroupID`), CONSTRAINT `FK_mri_violations_log_candidate_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `violations_resolved` ( `ID` bigint(20) NOT NULL AUTO_INCREMENT, `hash` varchar(255) NOT NULL, `ExtID` bigint(20) NOT NULL, `TypeTable` varchar(255) DEFAULT NULL, `User` varchar(255) DEFAULT NULL, `ChangeDate` datetime DEFAULT NULL, `Resolved` enum('unresolved', 'reran', 'emailed', 'inserted', 'rejected', 'inserted_flag', 'other') DEFAULT 'unresolved', PRIMARY KEY (`ID`), KEY `i_violations_resolved_extid_type` (`ExtID`,`TypeTable`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_protocol_violated_scans` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `CandidateID` int(10) unsigned, `PSCID` varchar(255), `TarchiveID` int(11), `time_run` datetime, `series_description` varchar(255) DEFAULT NULL, `minc_location` varchar(255), `PatientName` varchar(255) DEFAULT NULL, `TR_range` varchar(255) DEFAULT NULL, `TE_range` varchar(255) DEFAULT NULL, `TI_range` varchar(255) DEFAULT NULL, `slice_thickness_range` varchar(255) DEFAULT NULL, `xspace_range` varchar(255) DEFAULT NULL, `yspace_range` varchar(255) DEFAULT NULL, `zspace_range` varchar(255) DEFAULT NULL, `xstep_range` varchar(255) DEFAULT NULL, `ystep_range` varchar(255) DEFAULT NULL, `zstep_range` varchar(255) DEFAULT NULL, `time_range` varchar(255) DEFAULT NULL, `SeriesUID` varchar(64) DEFAULT NULL, `image_type` varchar(255) default NULL, `PhaseEncodingDirection` VARCHAR(3) DEFAULT NULL, `EchoNumber` VARCHAR(20) DEFAULT NULL, `MriProtocolGroupID` INT(4) UNSIGNED DEFAULT NULL, PRIMARY KEY (`ID`), KEY `TarchiveID` (`TarchiveID`), CONSTRAINT `FK_mri_violated_1` FOREIGN KEY (`TarchiveID`) REFERENCES `tarchive` (`TarchiveID`), CONSTRAINT `FK_mri_violated_2` FOREIGN KEY (`MriProtocolGroupID`) REFERENCES `mri_protocol_group` (`MriProtocolGroupID`), CONSTRAINT `FK_mri_protocol_violated_scans_candidate_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- document_repository tables -- ******************************** CREATE TABLE `document_repository_categories` ( `id` int(3) unsigned NOT NULL AUTO_INCREMENT, `category_name` varchar(255) DEFAULT NULL, `parent_id` int(3), `comments` text, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `document_repository` ( `record_id` int(11) NOT NULL AUTO_INCREMENT, `PSCID` varchar(255) DEFAULT NULL, `Instrument` varchar(255) DEFAULT NULL, `visitLabel` varchar(255) DEFAULT NULL, `Date_taken` date DEFAULT NULL, `Date_uploaded` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `Data_dir` varchar(255) DEFAULT NULL, `File_name` varchar(255) DEFAULT NULL, `File_type` varchar(20) DEFAULT NULL, `version` varchar(20) DEFAULT NULL, `File_size` bigint(20) unsigned DEFAULT NULL, `uploaded_by` varchar(255) DEFAULT NULL, `For_site` int(2) DEFAULT NULL, `comments` text, `multipart` enum('Yes','No') DEFAULT NULL, `EARLI` tinyint(1) DEFAULT 0, `hide_video` tinyint(1) DEFAULT 0, `File_category` int(3) unsigned DEFAULT NULL, PRIMARY KEY (`record_id`), KEY `fk_document_repository_1_idx` (`File_category`), CONSTRAINT `fk_document_repository_1` FOREIGN KEY (`File_category`) REFERENCES `document_repository_categories` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- Notification tables -- ******************************** CREATE TABLE `notification_types` ( `NotificationTypeID` int(11) NOT NULL auto_increment, `Type` varchar(255) NOT NULL default '', `private` tinyint(1) default 0, `Description` text, PRIMARY KEY (`NotificationTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `notification_types` (Type,private,Description) VALUES ('mri new study',0,'New studies processed by the MRI upload handler'), ('mri new series',0,'New series processed by the MRI upload handler'), ('mri upload handler emergency',1,'MRI upload handler emergencies'), ('mri staging required',1,'New studies received by the MRI upload handler that require staging'), ('mri invalid study',0,'Incorrectly labelled studies received by the MRI upload handler'), ('hardcopy request',0,'Hardcopy requests'), ('visual bvl qc',0,'Timepoints selected for visual QC'), ('mri qc status',0,'MRI QC Status change'), ('minc insertion',1,'Insertion of a MINC file into the MRI tables (files/parameter_file)'), ('tarchive loader',1,'calls specific Insertion Scripts'), ('tarchive validation',1,'Validation of the dicoms After uploading'), ('mri upload runner',1,'Validation of DICOMS before uploading'), ('mri upload processing class',1,'Validation and execution of DicomTar.pl and TarchiveLoader'), ('imaging non minc file insertion', 1, 'Insertion of a non-MINC file into the MRI tables (files/parameter_file)'), ('hrrt pet new series', 0, 'New HRRT PET studies inserted into the database'); CREATE TABLE `notification_spool` ( `NotificationID` int(11) NOT NULL auto_increment, `NotificationTypeID` int(11) NOT NULL, `ProcessID` int(11) DEFAULT NULL, `TimeSpooled` datetime DEFAULT NULL, `Message` text, `Error` enum('Y','N') default NULL, `Verbose` enum('Y','N') NOT NULL DEFAULT 'N', `Sent` enum('N','Y') NOT NULL default 'N', `CenterID` integer unsigned default NULL, `Origin` varchar(255) DEFAULT NULL, `Active` enum('Y', 'N') NOT NULL DEFAULT 'Y', PRIMARY KEY (`NotificationID`), KEY `FK_notification_spool_1` (`NotificationTypeID`), KEY `FK_notification_spool_2` (`CenterID`), CONSTRAINT `FK_notification_spool_2` FOREIGN KEY (`CenterID`) REFERENCES `psc` (`CenterID`), CONSTRAINT `FK_notification_spool_1` FOREIGN KEY (`NotificationTypeID`) REFERENCES `notification_types` (`NotificationTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `notification_modules` ( `id` int(10) unsigned auto_increment NOT NULL, `module_name` varchar(100) NOT NULL, `operation_type` varchar(100) NOT NULL, `as_admin` enum('Y','N') NOT NULL DEFAULT 'N', `template_file` varchar(100) NOT NULL, `description` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`), KEY (`module_name`), UNIQUE(module_name,operation_type) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `notification_services` ( `id` int(10) unsigned auto_increment NOT NULL, `service` VARCHAR(50) NOT NULL, PRIMARY KEY (`id`), UNIQUE(service) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- Associates modules with the service available for each CREATE TABLE `notification_modules_services_rel` ( `module_id` int(10) unsigned NOT NULL, `service_id` int(10) unsigned NOT NULL, PRIMARY KEY (`module_id`,`service_id`), KEY `FK_notification_modules_services_rel_1` (`module_id`), KEY `FK_notification_modules_services_rel_2` (`service_id`), CONSTRAINT `FK_notification_modules_services_rel_1` FOREIGN KEY (`module_id`) REFERENCES `notification_modules` (`id`), CONSTRAINT `FK_notification_modules_services_rel_2` FOREIGN KEY (`service_id`) REFERENCES `notification_services` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- saves users preferences for notification type CREATE TABLE `users_notifications_rel` ( `user_id` int(10) unsigned NOT NULL, `module_id` int(10) unsigned NOT NULL, `service_id` int(10) unsigned NOT NULL, PRIMARY KEY (`user_id`,`module_id`,`service_id`), KEY `FK_notifications_users_rel_1` (`user_id`), KEY `FK_notifications_users_rel_2` (`module_id`), KEY `FK_notifications_users_rel_3` (`service_id`), CONSTRAINT `FK_notifications_users_rel_1` FOREIGN KEY (`user_id`) REFERENCES `users` (`ID`), CONSTRAINT `FK_notifications_users_rel_2` FOREIGN KEY (`module_id`) REFERENCES `notification_modules` (`id`), CONSTRAINT `FK_notifications_users_rel_3` FOREIGN KEY (`service_id`) REFERENCES `notification_services` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- history log CREATE TABLE `notification_history` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `module_id` int(10) unsigned NOT NULL, `service_id` int(10) unsigned NOT NULL, `date_sent` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `trigger_user` int(10) unsigned NOT NULL, `target_user` int(10) unsigned NOT NULL, PRIMARY KEY (`id`), KEY `FK_notification_history_1` (`trigger_user`), KEY `FK_notification_history_2` (`target_user`), CONSTRAINT `FK_notification_history_1` FOREIGN KEY (`trigger_user`) REFERENCES `users` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_notification_history_2` FOREIGN KEY (`target_user`) REFERENCES `users` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- basic notification service INSERT INTO notification_services (service) VALUES ('email_text'); -- Pre-implemented notifications INSERT INTO notification_modules (module_name, operation_type, as_admin, template_file, description) VALUES ('media', 'upload', 'N', 'notifier_media_upload.tpl', 'Media: New File Uploaded'), ('media', 'download', 'N', 'notifier_media_download.tpl', 'Media: File Downloaded'), ('document_repository', 'new_category', 'N', 'notifier_document_repository_new_category.tpl', 'Document Repository: New Category'), ('document_repository', 'upload', 'N', 'notifier_document_repository_upload.tpl', 'Document Repository: New Document Uploaded'), ('document_repository', 'delete', 'N', 'notifier_document_repository_delete.tpl', 'Document Repository: Document Deleted'), ('document_repository', 'edit', 'N', 'notifier_document_repository_edit.tpl', 'Document Repository: Document Edited'), ('publication', 'submission', 'N', 'notifier_publication_submission.tpl', 'Publication: Submission Received'), ('publication', 'review', 'N', 'notifier_publication_review.tpl', 'Publication: Proposal has been reviewed'), ('publication', 'edit', 'N', 'notifier_publication_edit.tpl', 'Publication: Proposal has been edited'), ('issue_tracker', 'create/edit', 'N', 'issue_change.tpl', 'Issue Tracker: All issues created or edited'); INSERT INTO notification_modules_services_rel SELECT nm.id, ns.id FROM notification_modules nm JOIN notification_services ns WHERE nm.module_name='document_repository' AND ns.service='email_text'; INSERT INTO notification_modules_services_rel SELECT nm.id, ns.id FROM notification_modules nm JOIN notification_services ns WHERE nm.module_name='publication' AND ns.service='email_text'; INSERT INTO notification_modules_services_rel SELECT nm.id, ns.id FROM notification_modules nm JOIN notification_services ns WHERE nm.module_name='issue_tracker' AND ns.service='email_text'; -- Transfer Document repository notifications to new system INSERT INTO users_notifications_rel SELECT u.ID, nm.id, ns.id FROM users u JOIN notification_modules nm JOIN notification_services ns WHERE nm.module_name='document_repository' AND ns.service='email_text' AND u.Doc_Repo_Notifications='Y'; -- ******************************** -- conflict_resolver tables -- ******************************** CREATE TABLE `conflicts_unresolved` ( `ConflictID` int(10) NOT NULL AUTO_INCREMENT, `TestName` varchar(255) NOT NULL, `ExtraKeyColumn` varchar(255) DEFAULT NULL, `ExtraKey1` varchar(255) NOT NULL, `ExtraKey2` varchar(255) NOT NULL, `FieldName` varchar(255) NOT NULL, `CommentId1` varchar(255) NOT NULL, `Value1` text DEFAULT NULL, `CommentId2` varchar(255) NOT NULL, `Value2` text DEFAULT NULL, PRIMARY KEY (`ConflictID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `conflicts_resolved` ( `ResolvedID` int(10) NOT NULL AUTO_INCREMENT, `UserID` varchar(255) NOT NULL, `ResolutionTimestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `User1` varchar(255) DEFAULT NULL, `User2` varchar(255) DEFAULT NULL, `TestName` varchar(255) NOT NULL, `ExtraKeyColumn` varchar(255) DEFAULT NULL, `ExtraKey1` varchar(255) NOT NULL DEFAULT '', `ExtraKey2` varchar(255) NOT NULL DEFAULT '', `FieldName` varchar(255) NOT NULL, `CommentId1` varchar(255) NOT NULL, `CommentId2` varchar(255) NOT NULL, `OldValue1` text DEFAULT NULL, `OldValue2` text DEFAULT NULL, `NewValue` text DEFAULT NULL, `ConflictID` int(10) DEFAULT NULL, PRIMARY KEY (`ResolvedID`), UNIQUE KEY `ConflictID` (`ConflictID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- candidate_parameter tables -- ******************************** CREATE TABLE `participant_status_options` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `Description` varchar(255) DEFAULT NULL, `Required` tinyint(1) DEFAULT NULL, `parentID` int(10) DEFAULT NULL, PRIMARY KEY (`ID`), UNIQUE KEY `ID` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `participant_status_options` (Description, Required) VALUES ('Active',0), ('Refused/Not Enrolled',0), ('Ineligible',0), ('Excluded',0), ('Inactive',1), ('Incomplete',1), ('Complete',0); INSERT INTO `participant_status_options` (Description, Required, parentID) VALUES ('Unsure',NULL,@tmp_val), ('Requiring Further Investigation',NULL,@tmp_val), ('Not Responding',NULL,@tmp_val); SET @tmp_val = NULL; INSERT INTO `participant_status_options` (Description, Required, parentID) VALUES ('Death',NULL,@tmp_val), ('Lost to Followup',NULL,@tmp_val); SET @tmp_val = NULL; CREATE TABLE `participant_status` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `CandidateID` int(10) unsigned NOT NULL, `UserID` varchar(255) DEFAULT NULL, `entry_staff` varchar(255) DEFAULT NULL, `data_entry_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `participant_status` int(10) unsigned DEFAULT NULL, `participant_suboptions` int(10) unsigned DEFAULT NULL, `reason_specify` text, `reason_specify_status` enum('dnk','not_applicable','refusal','not_answered') DEFAULT NULL, PRIMARY KEY (`ID`), UNIQUE KEY `CandidateID` (`CandidateID`), UNIQUE KEY `ID` (`ID`), KEY `fk_participant_status_1_idx` (`participant_status`), KEY `fk_participant_status_2_idx` (`participant_suboptions`), CONSTRAINT `fk_participant_status_1` FOREIGN KEY (`participant_status`) REFERENCES `participant_status_options` (`ID`) ON DELETE SET NULL ON UPDATE CASCADE, CONSTRAINT `fk_participant_status_2` FOREIGN KEY (`participant_suboptions`) REFERENCES `participant_status_options` (`ID`) ON DELETE SET NULL ON UPDATE CASCADE, CONSTRAINT `fk_participant_status_3` FOREIGN KEY (`CandidateID`) REFERENCES `candidate` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `participant_accounts` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `SessionID` int(6) DEFAULT NULL, `Test_name` varchar(255) DEFAULT NULL, `Status` enum('Created','Sent','In Progress','Complete') DEFAULT NULL, `OneTimePassword` varchar(16) DEFAULT NULL, `CommentID` varchar(255) DEFAULT NULL, `UserEaseRating` varchar(1) DEFAULT NULL, `UserComments` text, PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `participant_emails` ( `Test_name` varchar(255) NOT NULL, `DefaultEmail` mediumtext, PRIMARY KEY (`Test_name`), CONSTRAINT `fk_participant_emails_1` FOREIGN KEY (`Test_name`) REFERENCES `test_names` (`Test_name`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ; CREATE TABLE `participant_status_history` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `CandidateID` int(10) unsigned NOT NULL, `entry_staff` varchar(255) DEFAULT NULL, `data_entry_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `participant_status` int(11) DEFAULT NULL, `reason_specify` varchar(255) DEFAULT NULL, `reason_specify_status` enum('not_answered') DEFAULT NULL, `participant_subOptions` int(11) DEFAULT NULL, PRIMARY KEY (`ID`), UNIQUE KEY `ID` (`ID`), CONSTRAINT `FK_participant_status_history_candidate_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `family` ( `ID` int(10) NOT NULL AUTO_INCREMENT, `FamilyID` int(6) NOT NULL, `CandidateID` int(10) unsigned NOT NULL, `Relationship_type` enum('half_sibling','full_sibling','1st_cousin') DEFAULT NULL, PRIMARY KEY (`ID`), CONSTRAINT `FK_family_candidate_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- Training tables -- ******************************** CREATE TABLE `examiners` ( `examinerID` int(10) unsigned NOT NULL auto_increment, `full_name` varchar(255) default NULL, `radiologist` tinyint(1) default 0 NOT NULL, `userID` int(10) unsigned DEFAULT NULL, PRIMARY KEY (`examinerID`), UNIQUE KEY `unique_examiner` (`full_name`,`userID`), UNIQUE KEY `FK_examiners_2` (`userID`), CONSTRAINT `FK_examiners_2` FOREIGN KEY (`userID`) REFERENCES `users` (`ID`) ON DELETE SET NULL ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `examiners_psc_rel` ( `examinerID` int(10) unsigned NOT NULL, `centerID` integer unsigned NOT NULL, `active` enum('Y','N') NOT NULL DEFAULT 'Y', `pending_approval` enum('Y','N') NOT NULL DEFAULT 'N', PRIMARY KEY (`examinerID`,`centerID`), KEY `FK_examiners_psc_rel_2` (`centerID`), CONSTRAINT `FK_examiners_psc_rel_1` FOREIGN KEY (`examinerID`) REFERENCES `examiners` (`examinerID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `FK_examiners_psc_rel_2` FOREIGN KEY (`centerID`) REFERENCES `psc` (`CenterID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- REDCap examiner INSERT INTO examiners (full_name) VALUES ('REDCap'); INSERT IGNORE INTO examiners_psc_rel (examinerID, centerID, active, pending_approval) SELECT e.examinerID, p.CenterID, "Y", "N" from psc p JOIN examiners e WHERE e.Full_name = "REDCap"; CREATE TABLE `certification` ( `certID` int(10) unsigned NOT NULL AUTO_INCREMENT, `examinerID` int(10) unsigned NOT NULL, `date_cert` date DEFAULT NULL, `visit_label` varchar(255) DEFAULT NULL, `testID` int(10) UNSIGNED NOT NULL, `pass` enum('not_certified','in_training','certified') DEFAULT NULL, `comment` varchar(255) DEFAULT NULL, PRIMARY KEY (`certID`,`testID`), CONSTRAINT `FK_certifcation_1` FOREIGN KEY (`testID`) REFERENCES `test_names` (`ID`), CONSTRAINT `FK_certifcation_2` FOREIGN KEY (`examinerID`) REFERENCES `examiners` (`examinerID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `certification_history` ( `id` int(11) NOT NULL AUTO_INCREMENT, `col` varchar(255) NOT NULL DEFAULT '', `old` text, `old_date` date DEFAULT NULL, `new` text, `new_date` date DEFAULT NULL, `primaryCols` varchar(255) DEFAULT 'certID', `primaryVals` text, `testID` int(3) DEFAULT NULL, `visit_label` varchar(255) DEFAULT NULL, `changeDate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `userID` varchar(255) NOT NULL DEFAULT '', `type` char(1) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='primaryVals should always contain a valid certID from the certification table'; -- ******************************** -- user_account_history tables -- ******************************** CREATE TABLE `user_account_history` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `UserID` varchar(255) NOT NULL DEFAULT '', `PermID` int(10) unsigned DEFAULT NULL, `PermAction` enum('I','D') DEFAULT NULL, `ChangeDate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- tables for policies -- ******************************** CREATE TABLE policies ( PolicyID INT AUTO_INCREMENT PRIMARY KEY, Name VARCHAR(255) NOT NULL, Version INT NOT NULL, ModuleID INT NOT NULL, PolicyRenewalTime INT DEFAULT 7, PolicyRenewalTimeUnit enum('D','Y','M','H') DEFAULT 'D', Content TEXT NULL, SwalTitle VARCHAR(255) DEFAULT 'Terms of Use', HeaderButton enum('Y','N') DEFAULT 'Y', HeaderButtonText VARCHAR(255) DEFAULT 'Terms of Use', Active enum('Y','N') DEFAULT 'Y', AcceptButtonText VARCHAR(255) DEFAULT 'Accept', DeclineButtonText VARCHAR(255) DEFAULT 'Decline', CreatedAt DATETIME DEFAULT CURRENT_TIMESTAMP, UpdatedAt DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP ); CREATE TABLE user_policy_decision ( ID INT AUTO_INCREMENT PRIMARY KEY, UserID INT NOT NULL, PolicyID INT NOT NULL, Decision enum('Accepted','Declined') NOT NULL, DecisionDate DATETIME DEFAULT CURRENT_TIMESTAMP ); -- ******************************** -- user_login_history tables -- ******************************** CREATE TABLE `user_login_history` ( `loginhistoryID` int(10) unsigned NOT NULL AUTO_INCREMENT, `userID` varchar(255) NOT NULL DEFAULT '', `Success` enum('Y','N') NOT NULL DEFAULT 'Y', `Failcode` varchar(2) DEFAULT NULL, `Fail_detail` varchar(255) DEFAULT NULL, `Login_timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `IP_address` varchar(255) DEFAULT NULL, `Page_requested` varchar(255) DEFAULT NULL, PRIMARY KEY (`loginhistoryID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- StatisticsTabs tables -- ******************************** CREATE TABLE `StatisticsTabs` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `ModuleName` varchar(255) NOT NULL, `SubModuleName` varchar(255) NOT NULL, `Description` varchar(255) DEFAULT NULL, `OrderNo` int(11) DEFAULT NULL, PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Stores list of tabs for the statistics module'; INSERT INTO StatisticsTabs (ModuleName, SubModuleName, Description, OrderNo) VALUES ('statistics', 'stats_general', 'General Description', 1), ('statistics', 'stats_demographic', 'Demographic Statistics', 2), ('statistics', 'stats_behavioural', 'Behavioural Statistics', 3), ('statistics', 'stats_MRI', 'Imaging Statistics', 4); -- ******************************** -- server_processes tables -- ******************************** CREATE TABLE `server_processes` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `pid` int(11) unsigned NOT NULL, `type` enum('mri_upload') NOT NULL, `stdout_file` varchar(255) DEFAULT NULL, `stderr_file` varchar(255) DEFAULT NULL, `exit_code_file` varchar(255) DEFAULT NULL, `exit_code` varchar(255) DEFAULT NULL, `userid` varchar(255) NOT NULL, `start_time` timestamp NULL DEFAULT NULL, `end_time` timestamp NULL DEFAULT NULL, `exit_text` text, PRIMARY KEY (`id`), KEY `FK_task_1` (`userid`), CONSTRAINT `FK_task_1` FOREIGN KEY (`userid`) REFERENCES `users` (`UserID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `mri_upload_server_processes_rel` ( `UploadID` int(10) unsigned NOT NULL, `ProcessID` int(10) unsigned NOT NULL, PRIMARY KEY (`UploadID`,`ProcessID`), CONSTRAINT `UK_mri_upload_server_processes_rel_ProcessID` UNIQUE KEY `ProcessID` (`ProcessID`), CONSTRAINT `FK_mri_upload_server_processes_rel_UploadID` FOREIGN KEY (`UploadID`) REFERENCES `mri_upload` (`UploadID`), CONSTRAINT `FK_mri_upload_server_processes_rel_ProcessID` FOREIGN KEY (`ProcessID`) REFERENCES `server_processes` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `media` ( `id` int(11) NOT NULL AUTO_INCREMENT, `session_id` int(10) unsigned NOT NULL, `instrument` varchar(255) DEFAULT NULL, `date_taken` date DEFAULT NULL, `comments` text, `file_name` varchar(255) NOT NULL, `file_type` varchar(255) DEFAULT NULL, `data_dir` varchar(255) NOT NULL, `uploaded_by` varchar(255) DEFAULT NULL, `hide_file` tinyint(1) DEFAULT 0, `last_modified` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `language_id` int(10) unsigned DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `file_name` (`file_name`), FOREIGN KEY (`session_id`) REFERENCES `session` (`ID`), FOREIGN KEY (`instrument`) REFERENCES `test_names` (`Test_name`), CONSTRAINT `FK_media_language` FOREIGN KEY (`language_id`) REFERENCES `language` (`language_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- issues tables -- ******************************** CREATE TABLE `issues_categories` ( `categoryID` int(11) unsigned NOT NULL AUTO_INCREMENT, `categoryName` varchar(255) NOT NULL DEFAULT '', PRIMARY KEY (`categoryID`), UNIQUE KEY `categoryName` (`categoryName`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO issues_categories (categoryName) VALUES ('Behavioural Battery'), ('Behavioural Instruments'), ('Data Entry'), ('Examiners'), ('Imaging'), ('Technical Issue'), ('User Accounts'), ('Other'); CREATE TABLE `issues` ( `issueID` int(11) unsigned NOT NULL AUTO_INCREMENT, `title` varchar(255) NOT NULL DEFAULT '', `reporter` varchar(255) NOT NULL DEFAULT '', `assignee` varchar(255) DEFAULT NULL, `status` enum('new','acknowledged','feedback','assigned','resolved','closed') NOT NULL DEFAULT 'new', `priority` enum('low','normal','high','urgent','immediate') NOT NULL DEFAULT 'low', `module` int(10) unsigned DEFAULT NULL, `dateCreated` datetime DEFAULT NULL, `lastUpdate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `lastUpdatedBy` varchar(255) DEFAULT NULL, `sessionID` int(10) unsigned DEFAULT NULL, `centerID` integer unsigned DEFAULT NULL, `CandidateID` int(10) unsigned DEFAULT NULL, `category` varchar(255) DEFAULT NULL, `description` longtext DEFAULT NULL, `instrument` int(10) unsigned DEFAULT NULL, PRIMARY KEY (`issueID`), KEY `fk_issues_1` (`reporter`), KEY `fk_issues_2` (`assignee`), KEY `fk_issues_3` (`CandidateID`), KEY `fk_issues_4` (`sessionID`), KEY `fk_issues_5` (`centerID`), KEY `fk_issues_6` (`lastUpdatedBy`), KEY `fk_issues_8` (`category`), KEY `fk_issues_instrument` (`instrument`), CONSTRAINT `fk_issues_8` FOREIGN KEY (`category`) REFERENCES `issues_categories` (`categoryName`), CONSTRAINT `fk_issues_1` FOREIGN KEY (`reporter`) REFERENCES `users` (`UserID`), CONSTRAINT `fk_issues_2` FOREIGN KEY (`assignee`) REFERENCES `users` (`UserID`), CONSTRAINT `fk_issues_3` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`), CONSTRAINT `fk_issues_4` FOREIGN KEY (`sessionID`) REFERENCES `session` (`ID`), CONSTRAINT `fk_issues_5` FOREIGN KEY (`centerID`) REFERENCES `psc` (`CenterID`), CONSTRAINT `fk_issues_6` FOREIGN KEY (`lastUpdatedBy`) REFERENCES `users` (`UserID`), CONSTRAINT `fk_issues_instrument` FOREIGN KEY (`instrument`) REFERENCES `test_names` (`ID`) ON DELETE RESTRICT ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `issues_history` ( `issueHistoryID` int(11) unsigned NOT NULL AUTO_INCREMENT, `newValue` longtext NOT NULL, `dateAdded` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `fieldChanged` enum('assignee','status','comment','sessionID','centerID','title','category','module','lastUpdatedBy','priority','candidateID', 'description','watching','instrument') NOT NULL DEFAULT 'comment', `issueID` int(11) unsigned NOT NULL, `addedBy` varchar(255) NOT NULL DEFAULT '', PRIMARY KEY (`issueHistoryID`), KEY `fk_issues_comments_1` (`issueID`), CONSTRAINT `fk_issues_comments_1` FOREIGN KEY (`issueID`) REFERENCES `issues` (`issueID`) ON DELETE CASCADE ON UPDATE RESTRICT ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `issues_comments` ( `issueCommentID` int(11) unsigned NOT NULL AUTO_INCREMENT, `issueID` int(11) unsigned NOT NULL, `dateAdded` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `addedBy` varchar(255) NOT NULL DEFAULT '', `issueComment` text NOT NULL, PRIMARY KEY (`issueCommentID`), KEY `fk_issue_comments_1` (`issueID`), CONSTRAINT `fk_issue_comments_1` FOREIGN KEY (`issueID`) REFERENCES `issues` (`issueID`) ON DELETE CASCADE ON UPDATE RESTRICT ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `issues_comments_history` ( `issueCommentHistoryID` int(11) unsigned NOT NULL AUTO_INCREMENT, `issueCommentID` int(11) unsigned NOT NULL, `dateEdited` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, `newValue` longtext NOT NULL, `editedBy` varchar(255) NOT NULL DEFAULT '', PRIMARY KEY (`issueCommentHistoryID`), KEY `fk_issues_comments_history` (`issueCommentID`), CONSTRAINT `fk_issues_comments_history` FOREIGN KEY (`issueCommentID`) REFERENCES `issues_comments` (`issueCommentID`) ON DELETE CASCADE ON UPDATE RESTRICT ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `issues_watching` ( `userID` varchar(255) NOT NULL DEFAULT '', `issueID` int(11) unsigned NOT NULL, PRIMARY KEY (`userID`,`issueID`), KEY `fk_issues_watching_2` (`issueID`), CONSTRAINT `fk_issues_watching_1` FOREIGN KEY (`userID`) REFERENCES `users` (`UserID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `issues_attachments` ( `ID` int(11) unsigned NOT NULL AUTO_INCREMENT, `issueID` int(11) unsigned NOT NULL, `file_hash` varchar(64) NOT NULL, `date_added` timestamp NOT NULL DEFAULT current_timestamp(), `file_name` varchar(255) NOT NULL DEFAULT '', `deleted` tinyint(1) NOT NULL DEFAULT 0, `user` varchar(255) NOT NULL DEFAULT '', `description` text DEFAULT NULL, `file_size` int(20) DEFAULT NULL, `mime_type` varchar(255) NOT NULL DEFAULT '', CONSTRAINT `fk_issues_attachments_issue` FOREIGN KEY (`issueID`) REFERENCES `issues` (`issueID`), PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- ******************************** -- parameter tables -- ******************************** CREATE TABLE `parameter_type` ( `ParameterTypeID` int(10) unsigned NOT NULL auto_increment, `Name` varchar(255) NOT NULL default '', `Alias` varchar(255) default NULL, `Type` text, `Description` text, `RangeMin` double default NULL, `RangeMax` double default NULL, `SourceField` text, `SourceFrom` VARCHAR(255), `SourceCondition` text, `Queryable` tinyint(1) default 1, `IsFile` tinyint(1) default 0, PRIMARY KEY (`ParameterTypeID`), KEY `name` (`Name`), UNIQUE `name_sourceFrom_index` (`Name`, `SourceFrom`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='dictionary of all the variables in the project'; INSERT INTO `parameter_type` (ParameterTypeID, Name, Type, Description, RangeMin, RangeMax, SourceField, SourceFrom, SourceCondition, Queryable, IsFile) VALUES (2,'Geometric_distortion','text',NULL,NULL,NULL,NULL,'parameter_file',NULL,0,0), (3,'Intensity_artifact','text',NULL,NULL,NULL,NULL,'parameter_file',NULL,0,0), (4,'Movement_artifacts_within_scan','text',NULL,NULL,NULL,NULL,'parameter_file',NULL,0,0), (5,'Movement_artifacts_between_packets','text',NULL,NULL,NULL,NULL,'parameter_file',NULL,0,0), (6,'Coverage','text',NULL,NULL,NULL,NULL,'parameter_file',NULL,0,0), (7,'md5hash','varchar(255)','md5hash magically created by NeuroDB::File',NULL,NULL,'parameter_file.Value','parameter_file',NULL,1,0), (8,'Color_Artifact','text',NULL,NULL,NULL,NULL,'parameter_file',NULL,0,0), (9,'Entropy','text',NULL,NULL,NULL,NULL,'parameter_file',NULL,0,0); INSERT INTO `parameter_type` (Name, Type, Description, RangeMin, RangeMax, SourceField, SourceFrom, Queryable, SourceCondition) VALUES ('candidate_label','text','Identifier_of_candidate',NULL,NULL,'PSCID','candidate',1,NULL), ('Visit_label','varchar(255)','Visit_label',NULL,NULL,'visit_label','session',1,NULL), ('candidate_dob','date','Candidate_Dob',NULL,NULL,'DoB','candidate',1,NULL); INSERT INTO `parameter_type` (Name, Alias, Type, Description, SourceFrom) VALUES ('slice_thickness','SliceThickness','text','Nominal reconstructed slice thickness (for tomographic imaging) or depth of field (for optical non-tomographic imaging), in mm. DICOM:0018_0050','parameter_file'), ('dicom_0x0018:el_0x0015','BodyPartExamined','text','Text description of the part of the body examined. Some IODs support the Anatomic Region Sequence (0008,2218), which can provide a more comprehensive mechanism for specifying the body part being examined. DICOM:0018_0015','parameter_file'), ('acquisition:num_slices','NumberOfSlices','text','The maximum number of Slices that may exist in this Series. DICOM:0054_0081','parameter_file'), ('pixel_bandwidth','PixelBandwidth','text','Reciprocal of the total sampling period, in hertz per pixel. DICOM:0018_0095','parameter_file'), ('acquisition_matrix','AcquisitionMatrixPE','text','Dimensions of the acquired frequency/phase data before reconstruction. Multi-valued: frequency rowsfrequency columnsphase rowsphase columns. DICOM:0018_1310','parameter_file'), ('study_id','StudyID','text','User or equipment generated Study identifier. DICOM:0020_0010','parameter_file'), ('modality','Modality','text','Type of equipment that originally acquired the data used to create images or related objects. DICOM:0008_0060','parameter_file'), ('sequence_variant','SequenceVariant','text','Variant of the Scanning Sequence. DICOM:0018_0021','parameter_file'), ('mr_acquisition_type','MRAcquisitionType','text','Identification of data encoding scheme. DICOM:0018_0023','parameter_file'), ('dicom_0x0028:el_0x0002','SamplesPerPixel','text','Number of samples (planes) in this image. DICOM:0028_0002','parameter_file'), ('patient_name','PatientName','text','Set of identifiers used to determine to which candidate the scan belongs to. DICOM:0010_0010','parameter_file'), ('dicom_0x0028:el_0x0004','PhotometricInterpretation','text','Specifies the intended interpretation of the pixel data. DICOM:0028_0004','parameter_file'), ('acquisition:start_time','PerformedProcedureStepStartTime','text','Time on which the Performed Procedure Step started. DICOM:0040_0245','parameter_file'), ('number_of_phase_encoding_steps','PhaseEncodingSteps','text','Total number of lines in k-space in the \"y\" direction collected during acquisition. DICOM:0018_0089','parameter_file'), ('percent_phase_field_of_view','PercentPhaseFOV','text','Ratio of field of view dimension in phase direction to field of view dimension in frequency direction, expressed as a percent. DICOM:0018_0094','parameter_file'), ('study:field_value','ValueField','text','The field within a Data Element that contains the Value(s) of that Data Element. DICOM:0000_0060','parameter_file'), ('largest_pixel_image_value','LargestPixelImageValue','text','The maximum actual pixel value encountered in this image. DICOM:0028_0107','parameter_file'), ('software_versions','SoftwareVersions','text','Manufacturers designation of software version of the equipment that produced the composite instances. DICOM:0018_1020','parameter_file'), ('spacing_between_slices','SpacingBetweenSlices','text','Spacing between slices, in mm, measured from center-to-center of each slice along the normal to the first image. The sign of the Spacing Between Slices (0018,0088) determines the direction of stacking. The normal is determined by the cross product of the direction cosines of the first row and first column of the first frame, such that a positive spacing indicates slices are stacked behind the first slice and a negative spacing indicates slices are stacked in front of the first slice. DICOM:0018_0088','parameter_file'), ('transmitting_coil','TransmitCoilName','text','Name of transmit coil used. DICOM:0018_1251','parameter_file'), ('cols','Columns','text','Number of columns in the image. DICOM:0028_0011','parameter_file'), ('number_of_averages','NumberOfAverages','text','Number of times a given pulse sequence is repeated before any parameter is changed. DICOM:0018_0083','parameter_file'), ('scanning_sequence','ScanningSequence','text','Description of the type of data taken. DICOM:0018_0020','parameter_file'), ('pixel_representation','PixelRepresentation','text','Data representation of the pixel samples. Each sample shall have the same pixel representation. DICOM:0028_0103','parameter_file'), ('phase_encoding_direction','InPlanePhaseEncodingDirectionDICOM','text','The axes of the in-plane phase encoding with respect to the frame. DICOM:0018_1312','parameter_file'), ('acquisition:dose_units','DoseUnits','text','Dose axis units. DICOM:3004_0002','parameter_file'), ('manufacturer','Manufacturer','text','Manufacturer of the equipment that produced the composite instances. Corresponds to DICOM Tag 0008, 0070 Manufacturer','parameter_file'), ('bits_allocated','BitsAllocated','text','Number of bits allocated for each pixel sample. Each sample shall have the same number of bits allocated. DICOM:0028_0100','parameter_file'), ('imaged_nucleus','ImagedNucleus','text','Nucleus that is resonant at the imaging frequency. Examples: 31P, 1H. DICOM:0018_0085','parameter_file'), ('image_position_patient','ImagePositionPatient','text','The x, y, and z coordinates of the upper left hand corner (center of the first voxel transmitted) of the image, in mm. DICOM:0020_0032','parameter_file'), ('sequence_name','SequenceName','text','Any arbitrary name of a molecular sequence. DICOM:0018_0024','parameter_file'), ('series_number','SeriesNumber','text','A number that identifies this Series. DICOM:0020_0011','parameter_file'), ('slice_location','SliceLocation','text','Relative position of the image plane expressed in mm. DICOM:0020_1041','parameter_file'), ('window_center','WindowCenter','text','Preferred value for Window Center (0028,1050) in the image instances produced by this reconstruction protocol element. DICOM:0028_1050','parameter_file'), ('echo_time','EchoTime','text','Time in ms between the middle of the excitation pulse and the peak of the echo produced (kx=0). In the case of segmented k-space, the TE(eff) is the time between the middle of the excitation pulse to the peak of the echo that is used to cover the center of k-space (i.e.,-kx=0, ky=0). DICOM:0018_0081','parameter_file'), ('manufacturer_model_name','ManufacturersModelName','text',"Manufacturer's model name of the equipment that produced the composite instances. Corresponds to DICOM Tag 0008, 1090 Manufacturers Model Name",'parameter_file'), ('dicominfo:image_type','ImageType','text','Image identification characteristics. DICOM:0008_0008','parameter_file'), ('window_width','WindowWidth','text','Window Width for display. DICOM:0028_1051','parameter_file'), ('repetition_time','RepetitionTime','text','The period of time in msec between the beginning of a pulse sequence and the beginning of the succeeding (essentially identical) pulse sequence. Required except when Scanning Sequence (0018,0020) is EP and Sequence Variant (0018,0021) is not SK.','parameter_file'), ('receiving_coil','ReceiveCoilName','text','Name of receive coil used. DICOM:0018_1250','parameter_file'), ('sar','SAR','text','Calculated whole body Specific Absorption Rate in watts/kilogram. DICOM:0018_1316','parameter_file'), ('patient_position','PatientPosition','text',"Description of imaging subject's position relative to the equipment. DICOM:0018_5100",'parameter_file'), ('window_center_width_explanation','WindowCenterWidthExplanation','text','Explanation of the Window Center and Width. DICOM:0028_1055','parameter_file'), ('high_bit','HighBit','text','Most significant bit for pixel sample data. Each sample shall have the same high bit. DICOM:0028_0102','parameter_file'), ('rows','Rows','text','Number of rows in the image. DICOM:0028_0010','parameter_file'), ('acquisition_number','AcquisitionNumber','text','A number identifying the single continuous gathering of data over a period of time that resulted in this image or instance, which may include multiple bed positions. This number is not required to be unique across SOP Instances in a series. DICOM:0020_0012','parameter_file'), ('echo_numbers','EchoNumber','text','The echo number used in generating this image. In the case of segmented k-space, it is the effective Echo Number. DICOM:0018_0086','parameter_file'), ('percent_sampling','PercentSampling','text','Fraction of acquisition matrix lines acquired, expressed as a percent. DICOM:0018_0093','parameter_file'), ('image_orientation_patient','ImageOrientationPatientDICOM','text','The direction cosines of the first row and the first column with respect to the patient. DICOM:0020_0037','parameter_file'), ('instance_number','InstanceNumber','text','A number that identifies this SOP Instance. DICOM:0020_0013','parameter_file'), ('echo_train_length','EchoTrainLength','text','Number of lines in k-space acquired per excitation of the same volume regardless of the type of echo or the number of frames derived from them. DICOM:0018_0091','parameter_file'), ('bits_stored','BitsStored','text','Number of bits stored for each pixel sample. Each sample shall have the same number of bits stored. See PS 3.5 for further explanation. DICOM:0028_0101','parameter_file'), ('protocol_name','ProtocolName','text','Description of the conditions under which the Series was performed. DICOM:0018_1030','parameter_file'), ('series_description','SeriesDescription','text','User provided description of the Series. DICOM:0008_103E','parameter_file'), ('magnetic_field_strength','MagneticFieldStrength','text','Nominal field strength of MR magnet in Tesla. DICOM:0018_0087','parameter_file'), ('dicom_0x0020:el_0x1002','ImagesInAcquisition','text','Number of images that resulted from this acquisition of data. DICOM:0020_1002','parameter_file'), ('dicom_0x0018:el_0x0025','AngioFlag','text','Angio Image Indicator. Primary image for Angio processing. Enumerated Values: Y Image is Angio N Image is not Angio. DICOM:0018_0025','parameter_file'), ('dicom_0x0018:el_0x9075','DiffusionDirectionality','text','Specifies whether diffusion conditions for the frame are directional, or isotropic with respect to direction. DICOM:0018_9075','parameter_file'), ('study_instance_uid','StudyInstanceUID','text','Unique identifier for the Study. DICOM:0020_000D','parameter_file'), ('pixel_spacing','PixelSpacing','text','Physical distance in the patient between the center of each pixel, specified by a numeric pair - adjacent row spacing (delimiter) adjacent column spacing in mm. DICOM:0028_0030','parameter_file'), ('patient:weight','PatientWeight','text','Weight of the patient in kilograms. DICOM:0010_1030','parameter_file'), ('variable_flip_angle_flag','VariableFlipAngle','text','Flip angle variation applied during image acquisition. DICOM:0018_1315','parameter_file'), ('dicom_0x0010:el_0x1030','PatientWeight','text','Weight of the patient in kilograms. DICOM:0010_1030','parameter_file'), ('imaging_frequency','ImagingFrequency','text','Precession frequency in MHz of the nucleus being imaged. DICOM:0018_0084','parameter_file'), ('acquisition:flip_angle','FlipAngle','text','Steady state angle in degrees to which the magnetic vector is flipped from the magnetic vector of the primary field. DICOM:0018_1314','parameter_file'), ('series_instance_uid','SeriesInstanceUID','text','Unique identifier for the Series that is part of the Study identified in Study Instance UID (0020,000D), if present, and contains the referenced object instance(s). DICOM:0020_000E','parameter_file'), ('smallest_pixel_image_value','SmallestPixelImageValue','text','The minimum actual pixel value encountered in this image. DICOM:0028_0106','parameter_file'), ('inversion_time','InversionTime','text','Time in msec after the middle of inverting RF pulse to middle of excitation pulse to detect the amount of longitudinal magnetization. Required if Scanning Sequence (0018,0020) has values of IR. DICOM:0018_0082','parameter_file'), ('dicom_0x0018:el_0x0022','ScanOptions','text','Parameters of scanning sequence. DICOM:0018_0022','parameter_file'), ('dicom_0x0020:el_0x0100','TemporalPositionIdentifier','text','Temporal order of a dynamic or functional set of Images. DICOM:0020_0100','parameter_file'), ('dicom_0x0008:el_0x9209','AcquisitionContrast','text','Indication of acquisition contrast used with frames in the SOP Instance. DICOM:0008_9209','parameter_file'), ('acquisition_time','AcquisitionTime','text','The time the acquisition of data that resulted in this image started. DICOM:0008_0032','parameter_file'), ('dicom_0x0018:el_0x1090','CardiacNumberOfImages','text','Number of images per cardiac cycle. DICOM:0018_1090','parameter_file'), ('dicom_0x0028:el_0x0006','PlanarConfiguration','text','Indicates whether the pixel data are encoded color-by-plane or color-by-pixel. DICOM:0028_0006','parameter_file'), ('dicom_0x0008:el_0x0064','ConversionType','text','Describes the kind of image conversion. DICOM:0008_0064','parameter_file'), ('dicom_0x0020:el_0x0020','PatientOrientation','text','Patient direction of the rows and columns of the image. DICOM:0020_0020','parameter_file'), ('dicom_0x0008:el_0x1032','ProcedureCodeSequence','text','A Sequence that conveys the type of procedure performed. DICOM:0008_1032','parameter_file'), ('dicom_0x0010:el_0x1020','PatientHeight','text',"Patient's height or length in meters. DICOM:0010_1020",'parameter_file'), ('dicom_0x0032:el_0x1064','StudyInstance','text','A sequence that conveys the requested procedure. One or more Items may be included in this Sequence. DICOM:0032_1064','parameter_file'), ('image_date','ContentDate','text','The date the data creation was started. For instance, this is the date the pixel data is created, not the date the data is acquired. DICOM:0008_0023','parameter_file'), ('acquisition_date','AcquisitionDate','text','The date the acquisition of data that resulted in this image started. DICOM:0008_0022','parameter_file'), ('series_date','SeriesDate','text','Date the Series started. DICOM:0008_0021','parameter_file'), ('image_time','ContentTime','text','The time the data creation was started. For instance, this is the time the pixel data is created, not the time the data is acquired. DICOM:0008_0033','parameter_file'), ('series_time','SeriesTime','text','Time the Series started. DICOM:0008_0031','parameter_file'), ('study_date','StudyDate','text','Date the Study started. DICOM:0008_0020','parameter_file'), ('study_time','StudyTime','text','Time the Study started. DICOM:0008_0030','parameter_file'), ('device_serial_number','DeviceSerialNumber','text',"Manufacturer's serial number of the device. DICOM:0018_1000",'parameter_file'), ('frame_of_reference_uid','FrameOfReferenceUID','text','Uniquely identifies the frame of reference for a Series. shall be used to uniquely identify a frame of reference for a series. Each series shall have a single Frame of Reference UID. However, multiple Series within a Study may share a Frame of Reference. DICOM:0020_0052','parameter_file'), ('image_comments','ImageComments','text','User-defined comments about the image. DICOM:0020_4000','parameter_file'), ('dicom_0x0028:el_0x1053','RescaleSlope','text','m in the equation specified by Rescale Intercept (0028,1052). DICOM:0028_1053','parameter_file'), ('dicom_0x0028:el_0x1054','RescaleType','text','Specifies the output units of Rescale Slope (0028,1053) and Rescale Intercept (0028,1052). DICOM:0028_1054','parameter_file'), ('dicom_0x0028:el_0x1052','RescaleIntercept','text','The value b in relationship between stored values (SV) and pixel value units (U) defined in Units (0054,1001): U = m*SV+b. DICOM:0028_1052','parameter_file'), ('institution_name','InstitutionName','text','Institution or organization to which the identified individual is responsible or accountable May also refer to the institution or organization at which the relevant equipment is located. DICOM:0008_0080','parameter_file'), ('study_description','StudyDescription','text','Institution-generated description or classification of the Study (component) performed. DICOM:0008_1030','parameter_file'), ('operator_name','OperatorName','text','Name(s) of the operator(s) who supporting this Series. DICOM:0008_1070','parameter_file'), ('patient_id','PatientID','text','A primary identifier for the patient. In the case of imaging a group of small animals simultaneously, the single value of this identifier corresponds to the identification of the entire group. DICOM:0010_0020','parameter_file'), ('patient_dob','PatientsBirthDate','text','Birth date of the patient. DICOM:0010_0030','parameter_file'), ('effective_series_duration','EffectiveDuration','text','Total time in seconds that data was actually taken for the entire Multi-frame image. DICOM:0018_0072','parameter_file'), ('spatial_resolution','SpatialResolution','text','The inherent limiting resolution in mm of the acquisition equipment for high contrast objects for the data gathering and reconstruction technique chosen. If variable across the images of the series, the value at the image center. DICOM:0018_1050','parameter_file'), ('fov_dimensions','FieldOfViewDimensions','text','Dimensions of the field of view, in mm. If Field of View Shape (0018,1147) is: RECTANGLE: row dimension followed by column. ROUND: diameter. HEXAGONAL: diameter of a circumscribed circle. DICOM:0018_1149','parameter_file'), ('laterality','Laterality','text','Laterality of (paired) body part examined. Required if the body part examined is a paired structure and Image Laterality (0020,0062) or Frame Laterality (0020,9072) are not sent. DICOM:0020_0060','parameter_file'), ('position_reference_indicator','PositionReferenceIndicator','text','Part of the imaging target used as a reference. DICOM:0020_1040','parameter_file'), ('pixel_padding_value','PixelPaddingValue','text','Value of pixels added to non-rectangular image to pad to rectangular format. DICOM:0028_0120','parameter_file'), ('HEDVersion', 'HEDVersion', 'text', 'HED Schema Version','physiological_parameter_file'), ('PhaseEncodingDirection',NULL,'text','BIDS PhaseEncodingDirection (a.k.a. i, i-, j, j-, k, k-)','parameter_file'); CREATE TABLE `parameter_type_category` ( `ParameterTypeCategoryID` int(11) unsigned NOT NULL auto_increment, `Name` varchar(255) default NULL, `Type` enum('Metavars','Instrument') default 'Metavars', PRIMARY KEY (`ParameterTypeCategoryID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `parameter_type_category` (Name, Type) VALUES ('MRI Variables','Metavars'), ('Identifiers', 'Metavars'), ('Electrophysiology Variables', 'Metavars'); CREATE TABLE `parameter_type_category_rel` ( `ParameterTypeID` int(11) unsigned NOT NULL, `ParameterTypeCategoryID` int(11) unsigned NOT NULL, PRIMARY KEY (`ParameterTypeCategoryID`,`ParameterTypeID`), KEY `FK_parameter_type_category_rel_1` (`ParameterTypeID`), CONSTRAINT `FK_parameter_type_category_rel_1` FOREIGN KEY (`ParameterTypeID`) REFERENCES `parameter_type` (`ParameterTypeID`) ON DELETE CASCADE, CONSTRAINT `FK_parameter_type_category_rel_2` FOREIGN KEY (`ParameterTypeCategoryID`) REFERENCES `parameter_type_category` (`ParameterTypeCategoryID`) ON DELETE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO parameter_type_category_rel (ParameterTypeID,ParameterTypeCategoryID) SELECT pt.ParameterTypeID,ptc.ParameterTypeCategoryID FROM parameter_type pt,parameter_type_category ptc WHERE ptc.Name='Identifiers' AND pt.Name IN ('candidate_label', 'Visit_label','candidate_dob'); CREATE TABLE `parameter_candidate` ( `ParameterCandidateID` int(10) unsigned NOT NULL auto_increment, `CandidateID` int(10) unsigned NOT NULL, `ParameterTypeID` int(10) unsigned NOT NULL, `Value` varchar(255) default NULL, `InsertTime` int(10) unsigned NOT NULL default 0, PRIMARY KEY (`ParameterCandidateID`), KEY `candidate_type` (`CandidateID`,`ParameterTypeID`), KEY `parameter_value` (`ParameterTypeID`,`Value`(64)), CONSTRAINT `FK_parameter_candidate_2` FOREIGN KEY (`CandidateID`) REFERENCES `candidate` (`ID`), CONSTRAINT `FK_parameter_candidate_1` FOREIGN KEY (`ParameterTypeID`) REFERENCES `parameter_type` (`ParameterTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='per-candidate equivalent of parameter_session'; CREATE TABLE `parameter_file` ( `ParameterFileID` int(10) unsigned NOT NULL auto_increment, `FileID` int(10) unsigned NOT NULL, `ParameterTypeID` int(10) unsigned NOT NULL, `Value` longtext, `InsertTime` int(10) unsigned NOT NULL default 0, PRIMARY KEY (`ParameterFileID`), UNIQUE KEY `file_type_uniq` (`FileID`,`ParameterTypeID`), KEY `parameter_value` (`ParameterTypeID`,`Value`(64)), CONSTRAINT `FK_parameter_file_2` FOREIGN KEY (`ParameterTypeID`) REFERENCES `parameter_type` (`ParameterTypeID`), CONSTRAINT `FK_parameter_file_1` FOREIGN KEY (`FileID`) REFERENCES `files` (`FileID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `parameter_session` ( `ParameterSessionID` int(10) unsigned NOT NULL auto_increment, `SessionID` int(10) unsigned NOT NULL, `ParameterTypeID` int(10) unsigned NOT NULL, `Value` varchar(255) default NULL, `InsertTime` int(10) unsigned NOT NULL default 0, PRIMARY KEY (`ParameterSessionID`), KEY `session_type` (`SessionID`,`ParameterTypeID`), KEY `parameter_value` (`ParameterTypeID`,`Value`(64)), CONSTRAINT `FK_parameter_session_2` FOREIGN KEY (`ParameterTypeID`) REFERENCES `parameter_type` (`ParameterTypeID`), CONSTRAINT `FK_parameter_session_1` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `parameter_type_override` ( `Name` varchar(255) NOT NULL, `Description` text, PRIMARY KEY (`Name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- genomic_browser tables -- ******************************** CREATE TABLE `genome_loc` ( `GenomeLocID` bigint(20) NOT NULL AUTO_INCREMENT, `Chromosome` varchar(255) DEFAULT NULL, `Strand` varchar(255) DEFAULT NULL, `EndLoc` int(11) DEFAULT NULL, `Size` int(11) DEFAULT NULL, `StartLoc` int(11) DEFAULT NULL, PRIMARY KEY (`GenomeLocID`), UNIQUE KEY `Chromosome` (`Chromosome`,`StartLoc`,`EndLoc`), KEY `Chromosome_2` (`Chromosome`,`EndLoc`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `gene` ( `GeneID` bigint(20) NOT NULL AUTO_INCREMENT, `Symbol` varchar(255) DEFAULT NULL, `Name` varchar(255) DEFAULT NULL, `NCBIID` varchar(255) DEFAULT NULL, `OfficialSymbol` varchar(255) DEFAULT NULL, `OfficialName` text, `GenomeLocID` bigint(20) DEFAULT NULL, PRIMARY KEY (`GeneID`), KEY `geneGenomeLocID` (`GenomeLocID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `genotyping_platform` ( `PlatformID` bigint(20) NOT NULL AUTO_INCREMENT, `Name` varchar(255) DEFAULT NULL, `Description` text, `TechnologyType` varchar(255) DEFAULT NULL, `Provider` varchar(255) DEFAULT NULL, PRIMARY KEY (`PlatformID`), UNIQUE KEY `Name` (`Name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `SNP` ( `SNPID` bigint(20) NOT NULL AUTO_INCREMENT, `rsID` varchar(20) DEFAULT NULL, `Description` text, `SNPExternalName` varchar(255) DEFAULT NULL, `SNPExternalSource` varchar(255) DEFAULT NULL, `ReferenceBase` enum('A','C','T','G') DEFAULT NULL, `MinorAllele` enum('A','C','T','G') DEFAULT NULL, `Markers` varchar(255) DEFAULT NULL, `FunctionPrediction` enum('exonic','ncRNAexonic','splicing','UTR3','UTR5') DEFAULT NULL, `Damaging` enum('D','NA') DEFAULT NULL, `ExonicFunction` enum('nonsynonymous','unknown') DEFAULT NULL, `Chromosome` varchar(255) DEFAULT NULL, `Strand` varchar(255) DEFAULT NULL, `EndLoc` int(11) DEFAULT NULL, `StartLoc` int(11) DEFAULT NULL, `Symbol` varchar(255) DEFAULT NULL, `Name` varchar(255) DEFAULT NULL, `NCBIID` varchar(255) DEFAULT NULL, `OfficialSymbol` varchar(255) DEFAULT NULL, `OfficialName` text, PRIMARY KEY (`SNPID`), UNIQUE KEY `uniq_snp` (`rsID`,`SNPExternalSource`), KEY `index3` (`Chromosome`,`StartLoc`,`EndLoc`,`Strand`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `SNP_candidate_rel` ( `ID` bigint(20) NOT NULL AUTO_INCREMENT, `SNPID` bigint(20) NOT NULL, `CandidateID` int(10) unsigned NOT NULL, `AlleleA` enum('A','C','T','G') DEFAULT NULL, `AlleleB` enum('A','C','T','G') DEFAULT NULL, `ArrayReport` enum('Normal','Uncertain','Pending') DEFAULT NULL, `ArrayReportDetail` varchar(255) DEFAULT NULL, `ValidationMethod` varchar(50) DEFAULT NULL, `Validated` enum('0','1') DEFAULT NULL, `GenotypeQuality` int(4) DEFAULT NULL, `PlatformID` bigint(20) DEFAULT NULL, PRIMARY KEY (`ID`), KEY `fk_SNP_candidate_rel_2` (`CandidateID`), KEY `fk_SNP_candidate_rel_1_idx` (`SNPID`), CONSTRAINT `fk_SNP_candidate_rel_1` FOREIGN KEY (`SNPID`) REFERENCES `SNP` (`SNPID`) ON DELETE NO ACTION ON UPDATE NO ACTION, CONSTRAINT `fk_SNP_candidate_rel_2` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ON DELETE NO ACTION ON UPDATE NO ACTION ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `CNV` ( `CNVID` bigint(20) NOT NULL AUTO_INCREMENT, `CandidateID` int(10) unsigned DEFAULT NULL, `Description` text, `Type` enum('gain','loss','unknown') DEFAULT NULL, `EventName` varchar(255) DEFAULT NULL, `Common_CNV` enum('Y','N') DEFAULT NULL, `Characteristics` enum('Benign','Pathogenic','Unknown') DEFAULT NULL, `CopyNumChange` int(11) DEFAULT NULL, `Inheritance` enum('de novo','NA','unclassified','unknown','maternal','paternal') DEFAULT NULL, `ArrayReport` enum('Normal','Abnormal','Pending','Uncertain') DEFAULT NULL, `Markers` varchar(255) DEFAULT NULL, `ArrayReportDetail` varchar(255) DEFAULT NULL, `ValidationMethod` varchar(50) DEFAULT NULL, `PlatformID` bigint(20) DEFAULT NULL, `Chromosome` varchar(255) DEFAULT NULL, `Strand` varchar(255) DEFAULT NULL, `EndLoc` int(11) DEFAULT NULL, `StartLoc` int(11) DEFAULT NULL, `Symbol` varchar(255) DEFAULT NULL, `Name` varchar(255) DEFAULT NULL, `NCBIID` varchar(255) DEFAULT NULL, `OfficialSymbol` varchar(255) DEFAULT NULL, `OfficialName` text, PRIMARY KEY (`CNVID`), KEY `PlatformID` (`PlatformID`), KEY `CandidateID` (`CandidateID`), KEY `index4` (`Chromosome`,`StartLoc`,`EndLoc`,`Strand`), CONSTRAINT `CNV_ibfk_1` FOREIGN KEY (`PlatformID`) REFERENCES `genotyping_platform` (`PlatformID`), CONSTRAINT `CNV_ibfk_3` FOREIGN KEY (`CandidateID`) REFERENCES `candidate` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `GWAS` ( `GWASID` int(10) unsigned NOT NULL AUTO_INCREMENT, `SNPID` bigint(20) NOT NULL, `rsID` varchar(20) DEFAULT NULL, `MajorAllele` enum('A','C','T','G') DEFAULT NULL, `MinorAllele` enum('A','C','T','G') DEFAULT NULL, `MAF` varchar(20) DEFAULT NULL, `Estimate` varchar(20) DEFAULT NULL, `StdErr` varchar(20) DEFAULT NULL, `Pvalue` varchar(20) DEFAULT NULL, PRIMARY KEY (`GWASID`), KEY `SNPID` (`SNPID`), CONSTRAINT `GWAS_ibfk_1` FOREIGN KEY (`SNPID`) REFERENCES `SNP` (`SNPID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='Stores results of Genome-Wide Analysis Study'; CREATE TABLE `genomic_analysis_modality_enum` ( `analysis_modality` varchar(100), PRIMARY KEY (`analysis_modality`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT IGNORE INTO `genomic_analysis_modality_enum` (analysis_modality) VALUES ('Methylation beta-values'), ('Other'); CREATE TABLE `genomic_files` ( `GenomicFileID` int unsigned NOT NULL AUTO_INCREMENT, `FileName` varchar(255) NOT NULL, `FilePackage` tinyint(1) DEFAULT NULL, `Description` varchar(255) NOT NULL, `FileType` varchar(255) NOT NULL, `FileSize` int(20) NOT NULL, `Platform` varchar(255) DEFAULT NULL, `Batch` varchar(255) DEFAULT NULL, `Source` varchar(255) DEFAULT NULL, `Date_taken` date DEFAULT NULL, `Category` enum('raw','cleaned') DEFAULT NULL, `Pipeline` varchar(255) DEFAULT NULL, `Algorithm` varchar(255) DEFAULT NULL, `Normalization` varchar(255) DEFAULT NULL, `SampleID` varchar(255) DEFAULT NULL, `AnalysisProtocol` varchar(255) DEFAULT NULL, `InsertedByUserID` varchar(255) NOT NULL DEFAULT '', `Date_inserted` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `Caveat` tinyint(1) DEFAULT NULL, `Notes` text, `AnalysisModality` varchar(100), PRIMARY KEY (`GenomicFileID`), KEY `AnalysisModality` (`AnalysisModality`), CONSTRAINT `genomic_files_ibfk_1` FOREIGN KEY (`AnalysisModality`) REFERENCES `genomic_analysis_modality_enum` (`analysis_modality`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `genomic_candidate_files_rel` ( `CandidateID` int(10) unsigned NOT NULL, `GenomicFileID` int(10) unsigned NOT NULL, PRIMARY KEY (`CandidateID`,`GenomicFileID`), KEY `GenomicFileID` (`GenomicFileID`), CONSTRAINT `genomic_candidate_files_rel_ibfk_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`), CONSTRAINT `genomic_candidate_files_rel_ibfk_2` FOREIGN KEY (`GenomicFileID`) REFERENCES `genomic_files` (`GenomicFileID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `genomic_sample_candidate_rel` ( `sample_label` varchar(100) NOT NULL, `CandidateID` int(10) unsigned NOT NULL, PRIMARY KEY (`sample_label`,`CandidateID`), UNIQUE KEY `sample_label` (`sample_label`), KEY `CandidateID` (`CandidateID`), CONSTRAINT `genomic_sample_candidate_rel_ibfk_1` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `genomic_cpg_annotation` ( `cpg_name` varchar(100) NOT NULL, `address_id_a` int(10) unsigned DEFAULT NULL, `probe_seq_a` varchar(100) DEFAULT NULL, `address_id_b` int(10) unsigned DEFAULT NULL, `probe_seq_b` varchar(100) DEFAULT NULL, `design_type` varchar(20) DEFAULT NULL, `color_channel` enum('Red','Grn') DEFAULT NULL, `genome_build` varchar(40) DEFAULT NULL, `probe_snp_10` varchar(40) DEFAULT NULL, `gene_name` text, `gene_acc_num` text, `gene_group` text, `island_loc` varchar(100) DEFAULT NULL, `island_relation` enum('island','n_shelf','n_shore','s_shelf','s_shore') DEFAULT NULL, `fantom_promoter_loc` varchar(100) DEFAULT NULL, `dmr` enum('CDMR','DMR','RDMR') DEFAULT NULL, `enhancer` tinyint(1) DEFAULT NULL, `hmm_island_loc` varchar(100) DEFAULT NULL, `reg_feature_loc` varchar(100) DEFAULT NULL, `reg_feature_group` varchar(100) DEFAULT NULL, `dhs` tinyint(1) DEFAULT NULL, `platform_id` bigint(20) DEFAULT NULL, `Chromosome` varchar(255) DEFAULT NULL, `Strand` varchar(255) DEFAULT NULL, `EndLoc` int(11) DEFAULT NULL, `StartLoc` int(11) DEFAULT NULL, PRIMARY KEY (`cpg_name`), KEY `platform_id` (`platform_id`), KEY `index3` (`Chromosome`,`StartLoc`,`EndLoc`,`Strand`), CONSTRAINT `genomic_cpg_annotation_ibfk_2` FOREIGN KEY (`platform_id`) REFERENCES `genotyping_platform` (`PlatformID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `genomic_cpg` ( `sample_label` varchar(100) NOT NULL, `cpg_name` varchar(100) NOT NULL, `beta_value` decimal(4,3) DEFAULT NULL, PRIMARY KEY (`sample_label`,`cpg_name`), KEY `cpg_name` (`cpg_name`), CONSTRAINT `genomic_cpg_ibfk_1` FOREIGN KEY (`sample_label`) REFERENCES `genomic_sample_candidate_rel` (`sample_label`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `genomic_cpg_ibfk_2` FOREIGN KEY (`cpg_name`) REFERENCES `genomic_cpg_annotation` (`cpg_name`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- External links -- ******************************** CREATE TABLE `ExternalLinkTypes` ( `LinkTypeID` int(11) NOT NULL AUTO_INCREMENT, `LinkType` varchar(255) DEFAULT NULL, PRIMARY KEY (`LinkTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `ExternalLinkTypes` (LinkType) VALUES ('FooterLink'), ('StudyLinks'), ('dashboard'); CREATE TABLE `ExternalLinks` ( `LinkID` int(11) NOT NULL AUTO_INCREMENT, `LinkTypeID` int(11) DEFAULT NULL, `LinkText` varchar(255) NOT NULL, `LinkURL` varchar(255) NOT NULL, PRIMARY KEY (`LinkID`), KEY `LinkTypeID` (`LinkTypeID`), CONSTRAINT `ExternalLinks_ibfk_1` FOREIGN KEY (`LinkTypeID`) REFERENCES `ExternalLinkTypes` (`LinkTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `ExternalLinks` (LinkTypeID, LinkText, LinkURL) VALUES ((SELECT LinkTypeID from ExternalLinkTypes WHERE LinkType='FooterLink'), 'Loris Website', 'http://www.loris.ca'), ((SELECT LinkTypeID from ExternalLinkTypes WHERE LinkType='FooterLink'), 'GitHub', 'https://github.com/aces/Loris'), ((SELECT LinkTypeID from ExternalLinkTypes WHERE LinkType='StudyLinks'), 'Loris Website', 'http://www.loris.ca'), ((SELECT LinkTypeID from ExternalLinkTypes WHERE LinkType='StudyLinks'), 'GitHub', 'https://github.com/aces/Loris'), ((SELECT LinkTypeID from ExternalLinkTypes WHERE LinkType='dashboard'), 'Loris Website', 'http://www.loris.ca'); -- ******************************** -- data_release -- ******************************** CREATE TABLE `data_release` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `file_name` varchar(255), `version` varchar(255), `upload_date` date, `ProjectID` INT(10) UNSIGNED NULL, PRIMARY KEY (`id`), FOREIGN KEY (ProjectID) REFERENCES Project (ProjectID) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `data_release_permissions` ( `userid` int(10) unsigned NOT NULL, `data_release_id` int(10) unsigned NOT NULL, PRIMARY KEY (`userid`, `data_release_id`), KEY `FK_userid` (`userid`), KEY `FK_data_release_id` (`data_release_id`), CONSTRAINT `FK_userid` FOREIGN KEY (`userid`) REFERENCES `users` (`ID`), CONSTRAINT `FK_data_release_id` FOREIGN KEY (`data_release_id`) REFERENCES `data_release` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- Acknowledgements -- ******************************** CREATE TABLE `acknowledgements` ( `ID` int(10) unsigned NOT NULL AUTO_INCREMENT, `ordering` varchar(255) DEFAULT NULL, `full_name` varchar(255) DEFAULT NULL, `citation_name` varchar(255) DEFAULT NULL, `affiliations` text DEFAULT NULL, `degrees` text DEFAULT NULL, `roles` text DEFAULT NULL, `start_date` date DEFAULT NULL, `end_date` date DEFAULT NULL, `present` enum('Yes', 'No') DEFAULT NULL, PRIMARY KEY (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- Feedback -- ******************************** CREATE TABLE `feedback_bvl_type` ( `Feedback_type` int(11) unsigned NOT NULL auto_increment, `Name` varchar(100) NOT NULL default '', `Description` text, PRIMARY KEY (`Feedback_type`), UNIQUE KEY `Name` (`Name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `feedback_bvl_type` (Name, Description) VALUES ('Input','Input Errors'), ('Scoring','Scoring Errors'); CREATE TABLE `feedback_bvl_thread` ( `FeedbackID` int(11) unsigned NOT NULL AUTO_INCREMENT, `CandidateID` int(10) unsigned DEFAULT NULL, `SessionID` int(11) unsigned DEFAULT NULL, `CommentID` varchar(255) DEFAULT NULL, `Feedback_level` enum('profile','visit','instrument') NOT NULL DEFAULT 'profile', `Feedback_type` int(11) unsigned DEFAULT NULL, `Public` enum('N','Y') NOT NULL DEFAULT 'N', `Status` enum('opened','answered','closed','comment') NOT NULL DEFAULT 'opened', `Active` enum('N','Y') NOT NULL DEFAULT 'N', `Date_taken` date DEFAULT NULL, `UserID` varchar(255) NOT NULL DEFAULT '', `Testdate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `FieldName` text, PRIMARY KEY (`FeedbackID`), KEY `FK_feedback_bvl_thread_1` (`Feedback_type`), KEY `FeedbackCandidate` (`CandidateID`), CONSTRAINT FK_feedback_bvl_thread_candidate_1 FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`), CONSTRAINT `FK_feedback_bvl_thread_1` FOREIGN KEY (`Feedback_type`) REFERENCES `feedback_bvl_type` (`Feedback_type`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `feedback_bvl_entry` ( `ID` int(11) unsigned NOT NULL auto_increment, `FeedbackID` int(11) unsigned default NULL, `Comment` text, `UserID` varchar(255) default NULL, `Testdate` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP, PRIMARY KEY (`ID`), KEY `FK_feedback_bvl_entry_1` (`FeedbackID`), CONSTRAINT `FK_feedback_bvl_entry_1` FOREIGN KEY (`FeedbackID`) REFERENCES `feedback_bvl_thread` (`FeedbackID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `feedback_mri_comment_types` ( `CommentTypeID` int(11) unsigned NOT NULL auto_increment, `CommentName` varchar(255) NOT NULL default '', `CommentType` enum('volume','visit') NOT NULL default 'volume', `CommentStatusField` varchar(255) NOT NULL default '', PRIMARY KEY (`CommentTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `feedback_mri_comment_types` (CommentName,CommentType,CommentStatusField) VALUES ('Geometric distortion','volume','a:2:{s:5:\"field\";s:20:\"Geometric_distortion\";s:6:\"values\";a:5:{i:0;s:0:\"\";i:1;s:4:\"Good\";i:2;s:4:\"Fair\";i:3;s:4:\"Poor\";i:4;s:12:\"Unacceptable\";}}'), ('Intensity artifact','volume','a:2:{s:5:\"field\";s:18:\"Intensity_artifact\";s:6:\"values\";a:5:{i:0;s:0:\"\";i:1;s:4:\"Good\";i:2;s:4:\"Fair\";i:3;s:4:\"Poor\";i:4;s:12:\"Unacceptable\";}}'), ('Movement artifact','volume','a:2:{s:5:\"field\";s:30:\"Movement_artifacts_within_scan\";s:6:\"values\";a:5:{i:0;s:0:\"\";i:1;s:4:\"None\";i:2;s:15:\"Slight Movement\";i:3;s:12:\"Poor Quality\";i:4;s:12:\"Unacceptable\";}}'), ('Packet movement artifact','volume','a:2:{s:5:\"field\";s:34:\"Movement_artifacts_between_packets\";s:6:\"values\";a:5:{i:0;s:0:\"\";i:1;s:4:\"None\";i:2;s:15:\"Slight Movement\";i:3;s:12:\"Poor Quality\";i:4;s:12:\"Unacceptable\";}}'), ('Coverage','volume','a:2:{s:5:\"field\";s:8:\"Coverage\";s:6:\"values\";a:5:{i:0;s:0:\"\";i:1;s:4:\"Good\";i:2;s:4:\"Fair\";i:3;s:5:\"Limit\";i:4;s:12:\"Unacceptable\";}}'), ('Overall','volume',''), ('Subject','visit',''), ('Dominant Direction Artifact (DWI ONLY)','volume','a:2:{s:5:"field";s:14:"Color_Artifact";s:6:"values";a:5:{i:0;s:0:"";i:1;s:4:"Good";i:2;s:4:"Fair";i:3;s:4:"Poor";i:4;s:12:"Unacceptable";}}'), ('Entropy Rating (DWI ONLY)','volume','a:2:{s:5:"field";s:7:"Entropy";s:6:"values";a:5:{i:0;s:0:"";i:1;s:10:"Acceptable";i:2;s:10:"Suspicious";i:3;s:12:"Unacceptable";i:4;s:13:"Not Available";}}'); CREATE TABLE `feedback_mri_predefined_comments` ( `PredefinedCommentID` int(11) unsigned NOT NULL auto_increment, `CommentTypeID` int(11) unsigned NOT NULL, `Comment` text NOT NULL, PRIMARY KEY (`PredefinedCommentID`), KEY `CommentType` (`CommentTypeID`), CONSTRAINT `FK_feedback_mri_predefined_comments_1` FOREIGN KEY (`CommentTypeID`) REFERENCES `feedback_mri_comment_types` (`CommentTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `feedback_mri_predefined_comments` (CommentTypeID, Comment) VALUES ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'missing slices'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'reduced dynamic range due to bright artifact/pixel'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'slice to slice intensity differences'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'noisy scan'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'susceptibilty artifact above the ear canals.'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'susceptibilty artifact due to dental work'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'sagittal ghosts'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Movement artifact'),'slight ringing artefacts'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Movement artifact'),'severe ringing artefacts'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Movement artifact'),'movement artefact due to eyes'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Movement artifact'),'movement artefact due to carotid flow'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Packet movement artifact'),'slight movement between packets'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Packet movement artifact'),'large movement between packets'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Large AP wrap around, affecting brain'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Medium AP wrap around, no affect on brain'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Small AP wrap around, no affect on brain'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Too tight LR, cutting into scalp'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Too tight LR, affecting brain'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Top of scalp cut off'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Top of brain cut off'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'Base of cerebellum cut off'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Coverage'),'missing top third - minc conversion?'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Overall'),'copy of prev data'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'checkerboard artifact'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'horizontal intensity striping (Venetian blind effect, DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'diagonal striping (NRRD artifact, DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'high intensity in direction of acquisition'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'signal loss (dark patches)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Dominant Direction Artifact (DWI ONLY)'),'red artifact'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Dominant Direction Artifact (DWI ONLY)'),'green artifact'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Dominant Direction Artifact (DWI ONLY)'),'blue artifact'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Overall'),'Too few remaining gradients (DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Overall'),'No b0 remaining after DWIPrep (DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Overall'),'No gradient information available from scanner (DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Overall'),'Incorrect diffusion direction (DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Overall'),'Duplicate series'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Movement artifact'),'slice wise artifact (DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Movement artifact'),'gradient wise artifact (DWI ONLY)'), ((SELECT `CommentTypeID` FROM `feedback_mri_comment_types` WHERE `CommentName`='Intensity artifact'),'susceptibility artifact due to anatomy'); CREATE TABLE `feedback_mri_comments` ( `CommentID` int(11) unsigned NOT NULL auto_increment, `FileID` int(10) unsigned default NULL, `SeriesUID` varchar(64) default NULL, `EchoTime` double default NULL, `PhaseEncodingDirection` VARCHAR(3) DEFAULT NULL, `EchoNumber` VARCHAR(20) DEFAULT NULL, `SessionID` int(10) unsigned default NULL, `CommentTypeID` int(11) unsigned NOT NULL, `PredefinedCommentID` int(11) unsigned default NULL, `Comment` text, `ChangeTime` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP, PRIMARY KEY (`CommentID`), KEY `FK_feedback_mri_comments_1` (`CommentTypeID`), KEY `FK_feedback_mri_comments_2` (`PredefinedCommentID`), KEY `FK_feedback_mri_comments_3` (`FileID`), KEY `FK_feedback_mri_comments_4` (`SessionID`), CONSTRAINT `FK_feedback_mri_comments_4` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`), CONSTRAINT `FK_feedback_mri_comments_1` FOREIGN KEY (`CommentTypeID`) REFERENCES `feedback_mri_comment_types` (`CommentTypeID`), CONSTRAINT `FK_feedback_mri_comments_2` FOREIGN KEY (`PredefinedCommentID`) REFERENCES `feedback_mri_predefined_comments` (`PredefinedCommentID`), CONSTRAINT `FK_feedback_mri_comments_3` FOREIGN KEY (`FileID`) REFERENCES `files` (`FileID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- Consent tables -- ******************************** CREATE TABLE `consent_group` ( `ConsentGroupID` integer unsigned NOT NULL AUTO_INCREMENT, `Name` varchar(255) NOT NULL, `Label` varchar(255) NOT NULL, CONSTRAINT `PK_consent_group` PRIMARY KEY (`ConsentGroupID`), CONSTRAINT `UK_consent_group_Name` UNIQUE KEY `Name` (`Name`), CONSTRAINT `UK_consent_group_Label` UNIQUE KEY `Label` (`Label`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `consent_group` (`ConsentGroupID`, `Name`, `Label`) VALUES ('1', 'main_consent', 'Main consent'); CREATE TABLE `consent` ( `ConsentID` integer unsigned NOT NULL AUTO_INCREMENT, `Name` varchar(255) NOT NULL, `Label` varchar(255) NOT NULL, `ConsentGroupID` integer unsigned NOT NULL DEFAULT 1, CONSTRAINT `PK_consent` PRIMARY KEY (`ConsentID`), CONSTRAINT `UK_consent_Name` UNIQUE KEY `Name` (`Name`), CONSTRAINT `UK_consent_Label` UNIQUE KEY `Label` (`Label`), CONSTRAINT `FK_consent_ConsentGroupID` FOREIGN KEY (`ConsentGroupID`) REFERENCES `consent_group` (`ConsentGroupID`) ON DELETE RESTRICT ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `candidate_consent_rel` ( `CandidateID` int(10) unsigned NOT NULL, `ConsentID` integer unsigned NOT NULL, `Status` enum('yes','no', 'not_applicable') DEFAULT NULL, `DateGiven` date DEFAULT NULL, `DateWithdrawn` date DEFAULT NULL, CONSTRAINT `PK_candidate_consent_rel` PRIMARY KEY (`CandidateID`,`ConsentID`), CONSTRAINT `FK_candidate_consent_rel_CandidateID` FOREIGN KEY (`CandidateID`) REFERENCES `candidate`(`ID`) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT `FK_candidate_consent_rel_ConsentID` FOREIGN KEY (`ConsentID`) REFERENCES `consent` (`ConsentID`) ON DELETE RESTRICT ON UPDATE RESTRICT ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `candidate_consent_history` ( `CandidateConsentHistoryID` int(10) unsigned NOT NULL AUTO_INCREMENT, `EntryDate` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, `DateGiven` date DEFAULT NULL, `DateWithdrawn` date DEFAULT NULL, `PSCID` varchar(255) NOT NULL, `ConsentName` varchar(255) NOT NULL, `ConsentLabel` varchar(255) NOT NULL, `Status` enum('yes','no', 'not_applicable') DEFAULT NULL, `EntryStaff` varchar(255) DEFAULT NULL, CONSTRAINT `PK_candidate_consent_history` PRIMARY KEY (`CandidateConsentHistoryID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `visit` ( `VisitID` int(10) unsigned NOT NULL auto_increment, `VisitName` varchar(100) NOT NULL, `VisitLabel` VARCHAR(200) UNIQUE NOT NULL, CONSTRAINT `PK_visit` PRIMARY KEY (`VisitID`), CONSTRAINT `UK_visit_name` UNIQUE KEY (`VisitName`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; CREATE TABLE `visit_project_cohort_rel` ( `VisitProjectCohortRelID` int(10) unsigned NOT NULL AUTO_INCREMENT, `VisitID` int(10) unsigned NOT NULL, `ProjectCohortRelID` int(10) unsigned NOT NULL, CONSTRAINT PK_visit_project_cohort_rel PRIMARY KEY (`VisitProjectCohortRelID`), CONSTRAINT UK_visit_project_cohort_rel_VisitID_ProjectCohortRelID UNIQUE KEY (`VisitID`, `ProjectCohortRelID`), CONSTRAINT FK_visit_project_cohort_rel_VisitID FOREIGN KEY (`VisitID`) REFERENCES `visit`(`VisitID`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT FK_visit_project_cohort_rel_ProjectCohortRelID FOREIGN KEY (`ProjectCohortRelID`) REFERENCES `project_cohort_rel`(`ProjectCohortRelID`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- Diagnosis Evolution CREATE TABLE `diagnosis_evolution` ( `DxEvolutionID` int(10) unsigned NOT NULL AUTO_INCREMENT, `Name` varchar(255) DEFAULT NULL, `ProjectID` int(10) unsigned NOT NULL, `visitLabel` varchar(255) DEFAULT NULL, `instrumentName` varchar(255) DEFAULT NULL, `sourceField` varchar(255) DEFAULT NULL, `orderNumber` int(10) unsigned DEFAULT NULL, CONSTRAINT `PK_diagnosis_evolution` PRIMARY KEY (`DxEvolutionID`), CONSTRAINT `UK_diagnosis_evolution_Name` UNIQUE KEY `Name` (`Name`), CONSTRAINT `FK_diagnosis_evolution_ProjectID` FOREIGN KEY (`ProjectID`) REFERENCES `Project` (`ProjectID`) ON DELETE RESTRICT ON UPDATE CASCADE, CONSTRAINT `FK_diagnosis_evolution_instrumentName` FOREIGN KEY (`instrumentName`) REFERENCES `test_names` (`Test_name`) ON DELETE RESTRICT ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `candidate_diagnosis_evolution_rel` ( `CandidateID` int(10) unsigned NOT NULL, `DxEvolutionID` int(10) unsigned NOT NULL, `Diagnosis` text DEFAULT NULL, `Confirmed` enum('Y', 'N') DEFAULT NULL, `LastUpdate` datetime NOT NULL DEFAULT NOW() ON UPDATE NOW(), CONSTRAINT `PK_candidate_diagnosis_evolution_rel` PRIMARY KEY (`CandidateID`, `DxEvolutionID`), CONSTRAINT `FK_candidate_diagnosis_evolution_rel_CandID` FOREIGN KEY (`CandidateID`) REFERENCES `candidate` (`ID`) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT `FK_candidate_diagnosis_evolution_rel_DxEvolutionID` FOREIGN KEY (`DxEvolutionID`) REFERENCES `diagnosis_evolution` (`DxEvolutionID`) ON DELETE RESTRICT ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- Publication Status CREATE TABLE `publication_status` ( `PublicationStatusID` int(2) unsigned NOT NULL AUTO_INCREMENT, `Label` varchar(255) NOT NULL, CONSTRAINT `PK_publication_status` PRIMARY KEY(`PublicationStatusID`), CONSTRAINT `UK_publication_status_Label` UNIQUE (`Label`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; INSERT INTO publication_status (`Label`) VALUES ('Pending'); INSERT INTO publication_status (`Label`) VALUES ('Approved'); INSERT INTO publication_status (`Label`) VALUES ('Rejected'); CREATE TABLE `publication_collaborator` ( `PublicationCollaboratorID` int(10) unsigned NOT NULL AUTO_INCREMENT, `Name` varchar(255) NOT NULL, `Email` varchar(255), CONSTRAINT `PK_publication_collaborator` PRIMARY KEY(`PublicationCollaboratorID`), CONSTRAINT `UK_publication_collaborator_Email` UNIQUE (`Email`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; -- Main table CREATE TABLE `publication` ( `PublicationID` int(10) unsigned NOT NULL AUTO_INCREMENT, `PublicationStatusID` int(2) unsigned NOT NULL default 1, `UserID` int(10) unsigned NOT NULL, `RatedBy` int(10) unsigned, `DateProposed` date NOT NULL, `DateRated` date default NULL, `Title` varchar(255) NOT NULL, `RejectedReason` varchar(255) default NULL, `Description` text NOT NULL, `journal` varchar(255) DEFAULT NULL, `doi` text DEFAULT NULL, `datePublication` date DEFAULT NULL, `link` varchar(255) DEFAULT NULL, `publishingStatus` enum('In Progress','Published') DEFAULT NULL, `project` int(10) unsigned DEFAULT NULL, `LeadInvestigator` VARCHAR(255) DEFAULT NULL, `LeadInvestigatorEmail` VARCHAR(255) DEFAULT NULL, CONSTRAINT `FK_publication_project` FOREIGN KEY (project) REFERENCES Project(ProjectID), CONSTRAINT `PK_publication` PRIMARY KEY(`PublicationID`), CONSTRAINT `FK_publication_UserID` FOREIGN KEY(`UserID`) REFERENCES `users` (`ID`), CONSTRAINT `FK_publication_RatedBy` FOREIGN KEY(`RatedBy`) REFERENCES `users` (`ID`), CONSTRAINT `FK_publication_PublicationStatusID` FOREIGN KEY(`PublicationStatusID`) REFERENCES `publication_status` (`PublicationStatusID`), CONSTRAINT `UK_publication_Title` UNIQUE (`Title`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; -- Separate table for Keywords CREATE TABLE `publication_keyword` ( `PublicationKeywordID` int(10) unsigned NOT NULL AUTO_INCREMENT, `Label` varchar(255) NOT NULL, CONSTRAINT `PK_publication_keyword` PRIMARY KEY(`PublicationKeywordID`), CONSTRAINT `UK_publication_Label` UNIQUE (`Label`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; -- Publication - Keyword relational table CREATE TABLE `publication_keyword_rel` ( `PublicationID` int(10) unsigned NOT NULL, `PublicationKeywordID` int(10) unsigned NOT NULL, CONSTRAINT `PK_publication_keyword_rel` PRIMARY KEY(PublicationID, PublicationKeywordID), CONSTRAINT `FK_publication_keyword_PublicationID` FOREIGN KEY(`PublicationID`) REFERENCES `publication` (`PublicationID`), CONSTRAINT `FK_publication_keyword_PublicationKeywordID` FOREIGN KEY(`PublicationKeywordID`) REFERENCES `publication_keyword` (`PublicationKeywordID`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; CREATE TABLE `publication_collaborator_rel` ( `PublicationID` int(10) unsigned NOT NULL, `PublicationCollaboratorID` int(10) unsigned NOT NULL, CONSTRAINT `PK_publication_collaborator_rel` PRIMARY KEY(PublicationID, PublicationCollaboratorID), CONSTRAINT `FK_publication_collaborator_rel_PublicationID` FOREIGN KEY(`PublicationID`) REFERENCES `publication` (`PublicationID`), CONSTRAINT `FK_publication_collaborator_rel_PublicationCollaboratorID` FOREIGN KEY(`PublicationCollaboratorID`) REFERENCES `publication_collaborator` (`PublicationCollaboratorID`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; -- Publication - Variable of Interest relational table CREATE TABLE `publication_parameter_type_rel` ( `PublicationID` int(10) unsigned NOT NULL, `ParameterTypeID` int(10) unsigned NOT NULL, CONSTRAINT `PK_publication_parameter_type_rel` PRIMARY KEY (PublicationID, ParameterTypeID), CONSTRAINT `FK_publication_parameter_type_rel_PublicationID` FOREIGN KEY (`PublicationID`) REFERENCES `publication` (`PublicationID`), CONSTRAINT `FK_publication_parameter_type_rel_ParameterTypeID` FOREIGN KEY (`ParameterTypeID`) REFERENCES `parameter_type` (`ParameterTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; CREATE TABLE `publication_test_names_rel` ( `PublicationID` int(10) unsigned NOT NULL, `TestNameID` int(10) unsigned NOT NULL, CONSTRAINT `PK_publication_test_names_rel` PRIMARY KEY(`PublicationID`, `TestNameID`), CONSTRAINT `FK_publication_test_names_rel_PublicationID` FOREIGN KEY (`PublicationID`) REFERENCES `publication` (`PublicationID`), CONSTRAINT `FK_publication_test_names_rel_TestNameID` FOREIGN KEY (`TestNameID`) REFERENCES `test_names` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; -- Publication Uploads CREATE TABLE `publication_upload_type` ( `PublicationUploadTypeID` int(2) unsigned NOT NULL AUTO_INCREMENT, `Label` varchar(255) NOT NULL, CONSTRAINT `PK_publication_upload_type` PRIMARY KEY (`PublicationUploadTypeID`), CONSTRAINT `UK_publication_Label` UNIQUE (`Label`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; INSERT INTO publication_upload_type (`Label`) VALUES ('Paper'); INSERT INTO publication_upload_type (`Label`) VALUES ('Poster'); INSERT INTO publication_upload_type (`Label`) VALUES ('Presentation'); INSERT INTO publication_upload_type (`Label`) VALUES ('Other'); CREATE TABLE `publication_upload` ( `PublicationUploadID` int(10) unsigned NOT NULL AUTO_INCREMENT, `PublicationID` int(10) unsigned NOT NULL, `PublicationUploadTypeID` int(2) unsigned NOT NULL, `Filename` varchar(255) NOT NULL, `Version` varchar(255), `Citation` text, CONSTRAINT `PK_publication_upload` PRIMARY KEY (`PublicationUploadID`), CONSTRAINT `UK_publication_upload_Filename` UNIQUE (Filename), CONSTRAINT `FK_publication_upload_PublicationID` FOREIGN KEY (`PublicationID`) REFERENCES `publication` (`PublicationID`), CONSTRAINT `FK_publication_upload_PublicationUploadTypeID` FOREIGN KEY (`PublicationUploadTypeID`) REFERENCES `publication_upload_type` (`PublicationUploadTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; CREATE TABLE `publication_users_edit_perm_rel` ( `PublicationID` int(10) unsigned NOT NULL AUTO_INCREMENT, `UserID` int(10) unsigned NOT NULL, CONSTRAINT `PK_publication_users_edit_perm_rel` PRIMARY KEY(`PublicationID`, `UserID`), CONSTRAINT `FK_publication_users_edit_perm_rel_PublicationID` FOREIGN KEY (`PublicationID`) REFERENCES `publication` (`PublicationID`), CONSTRAINT `FK_publication_users_edit_perm_rel_UserID` FOREIGN KEY (`UserID`) REFERENCES `users` (`ID`) ) ENGINE=InnoDB DEFAULT CHARSET='utf8'; CREATE TABLE login_summary_statistics ( Title VARCHAR(255), Project VARCHAR(255), Value INT, QueryOrder INT, PRIMARY KEY (Title, Project) ); CREATE TABLE dataquery_queries ( QueryID int(10) unsigned NOT NULL AUTO_INCREMENT, Query JSON NOT NULL, PRIMARY KEY (QueryID) -- FOREIGN KEY (Owner) REFERENCES users(ID) ); CREATE TABLE dataquery_query_names ( QueryID int(10) unsigned NOT NULL, UserID int(10) unsigned NOT NULL, Name varchar(255) NOT NULL, PRIMARY KEY (QueryID, UserID), FOREIGN KEY (QueryID) REFERENCES dataquery_queries(QueryID), FOREIGN KEY (UserID) REFERENCES users(ID) ); CREATE TABLE dataquery_run_queries ( RunID int(10) unsigned NOT NULL AUTO_INCREMENT, QueryID int(10) unsigned, UserID int(10) unsigned, RunTime TIMESTAMP DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (RunID), FOREIGN KEY (QueryID) REFERENCES dataquery_queries(QueryID), FOREIGN KEY (UserID) REFERENCES users(ID) ); CREATE TABLE dataquery_shared_queries_rel ( QueryID int(10) unsigned, SharedBy int(10) unsigned, FOREIGN KEY (QueryID) REFERENCES dataquery_queries(QueryID), FOREIGN KEY (SharedBy) REFERENCES users(ID), CONSTRAINT unique_share UNIQUE (QueryID, SharedBy) ); CREATE TABLE dataquery_starred_queries_rel ( QueryID int(10) unsigned, StarredBy int(10) unsigned, FOREIGN KEY (QueryID) REFERENCES dataquery_queries(QueryID), FOREIGN KEY (StarredBy) REFERENCES users(ID), CONSTRAINT unique_pin UNIQUE (QueryID, StarredBy) ); CREATE TABLE dataquery_run_results ( RunID int(10) unsigned NOT NULL AUTO_INCREMENT, CandidateID int(10) unsigned NOT NULL, -- JSON or same format that's streamed in? RowData LONGTEXT DEFAULT NULL, PRIMARY KEY (RunID, CandidateID), FOREIGN KEY (CandidateID) REFERENCES candidate(ID), FOREIGN KEY (RunID) REFERENCES dataquery_run_queries(RunID) ); CREATE TABLE dataquery_study_queries_rel ( QueryID int(10) unsigned, PinnedBy int(10) unsigned, -- A top query shows on the top of the dataquery tool similarly -- to a saved query but is chosen by admins, a dashboard query -- shows the number of matching results on the LORIS dashboard. Name varchar(255) NOT NULL, PinType enum('topquery', 'dashboard', 'loginpage'), FOREIGN KEY (QueryID) REFERENCES dataquery_queries(QueryID), FOREIGN KEY (PinnedBy) REFERENCES users(ID), CONSTRAINT unique_pin UNIQUE (QueryID, PinType) ); CREATE TABLE `appointment_type` ( `AppointmentTypeID` int(10) UNSIGNED NOT NULL, `Name` varchar(32) NOT NULL, PRIMARY KEY (`AppointmentTypeID`), UNIQUE KEY (`Name`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `appointment_type` (`AppointmentTypeID`, `Name`) VALUES (3, 'Behavioral'), (2, 'Blood Collection'), (1, 'MRI'); CREATE TABLE `appointment` ( `AppointmentID` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, `SessionID` int(10) UNSIGNED NOT NULL, `AppointmentTypeID` int(10) UNSIGNED NOT NULL, `StartsAt` datetime NOT NULL, PRIMARY KEY (`AppointmentID`), KEY `AppointmentTypeID` (`AppointmentTypeID`), KEY `SessionID` (`SessionID`), CONSTRAINT `appointment_belongsToSession` FOREIGN KEY (`SessionID`) REFERENCES `session` (`ID`), CONSTRAINT `appointment_hasAppointmentType` FOREIGN KEY (`AppointmentTypeID`) REFERENCES `appointment_type` (`AppointmentTypeID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `openid_connect_providers` ( `OpenIDProviderID` int(10) unsigned NOT NULL AUTO_INCREMENT, `Name` varchar(255) NOT NULL, `BaseURI` text NOT NULL, -- the provider's base uri that hosts .well-known/openid-configuration `ClientID` text NOT NULL, `ClientSecret` text NOT NULL, `RedirectURI` text NOT NULL, -- our local redirectURI that the provider is configured to authorize -- should be something like "https://something.loris.ca/oidc/callback" PRIMARY KEY (`OpenIDProviderID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `openid_connect_csrf` ( `State` varchar(64) NOT NULL UNIQUE, `OpenIDProviderID` int(10) unsigned NOT NULL AUTO_INCREMENT, `Nonce` varchar(64) NOT NULL, `Created` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`State`), CONSTRAINT `FK_openid_provider` FOREIGN KEY (`OpenIDProviderID`) REFERENCES `openid_connect_providers` (`OpenIDProviderID`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ******************************** -- REDCap tables -- ******************************** CREATE TABLE `redcap_notification` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `complete` char(1) NOT NULL, `project_id` varchar(50) NOT NULL, `record` varchar(20) NOT NULL COMMENT 'PSCID', `redcap_event_name` varchar(50) NOT NULL COMMENT 'Visit_label', `instrument` varchar(150) NOT NULL COMMENT 'Test_name', `username` varchar(100) NOT NULL, `redcap_url` varchar(255) NOT NULL, `project_url` varchar(255) NOT NULL, `received_dt` datetime NOT NULL, `handled_dt` datetime NULL, PRIMARY KEY (`id`), KEY `i_redcap_notif_received_dt` (`received_dt`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;