forge->addField([ 'SiteID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CodingSysID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'IntCountryID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'CountryID' => ['type' => 'VARCHAR', 'constraint' => 10], 'Country' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('IntCountryID', true); $this->forge->addUniqueKey('CountryID'); $this->forge->createTable('country'); // ethnic $this->forge->addField([ 'SiteID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CodingSysID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'EthnicID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'Ethnic' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('EthnicID', true); $this->forge->createTable('ethnic'); // patatt $this->forge->addField([ 'PatAttID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'InternalPID'=> ['type' => 'INT', 'constraint' => 11, 'null' => true], 'Address' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'UserID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'DelDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PatAttID', true); $this->forge->createTable('patatt'); // patcom $this->forge->addField([ 'PatComID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'InternalPID'=> ['type' => 'INT', 'constraint' => 11, 'null' => true], 'Comment' => ['type' => 'TEXT', 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PatComID', true); $this->forge->createTable('patcom'); // patdiag $this->forge->addField([ 'PatDiagID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'InternalPVID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'InternalPID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'DiagCode' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Comment' => ['type' => 'TEXT', 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], 'ArchivedDate' => ['type' => 'DATETIME', 'null' => true], 'DelDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PatDiagID', true); $this->forge->createTable('patdiag'); // patidt $this->forge->addField([ 'PatIdtID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'InternalPID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'IdentifierType'=> ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Identifier' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'EffectiveDate' => ['type' => 'DATETIME', 'null' => true], 'ExpirationDate'=> ['type' => 'DATETIME', 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'DelDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PatIdtID', true); $this->forge->createTable('patidt'); // patient $this->forge->addField([ 'InternalPID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'PatientID' => ['type' => 'VARCHAR', 'constraint' => 255], 'AlternatePID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Prefix' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'NameFirst' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'NameMiddle' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'NameMaiden' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'NameLast' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Suffix' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'NameAlias' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Gender' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'PlaceOfBirth' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Birthdate' => ['type' => 'DATETIME', 'null' => true], 'Street_1' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Street_2' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Street_3' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'City' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Province' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'ZIP' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'IntCountryID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'EmailAddress1' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'EmailAddress2' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Phone' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'MobilePhone' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Custodian' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'AccountNumber' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'RaceID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'MaritalStatus' => ['type' => 'VARCHAR', 'constraint' => 1, 'null' => true], 'ReligionID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'EthnicID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'Citizenship' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'DeathIndicator'=> ['type' => 'BIT', 'constraint' => 1, 'null' => true], 'DeathDateTime' => ['type' => 'DATETIME', 'null' => true], 'LinkTo' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'DelDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('InternalPID', true); $this->forge->addUniqueKey('PatientID'); $this->forge->addUniqueKey('AlternatePID'); $this->forge->addUniqueKey('EmailAddress1'); $this->forge->createTable('patient'); // patreglog $this->forge->addField([ 'PatRegLogID'=> ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'TblName' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'RecID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'FldName' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'FldValuePrev'=> ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'UserID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'SiteID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'DIDType' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'DID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'MachineID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'SessionID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'AppID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'ProcessID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'WebPageID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'EventID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'ActivityID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Reason' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'LogDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PatRegLogID', true); $this->forge->createTable('patreglog'); // patrelation $this->forge->addField([ 'PatRelID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'InternalPID'=> ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PatRelID', true); $this->forge->createTable('patrelation'); // patvisit $this->forge->addField([ 'SiteID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'InternalPVID'=> ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'PVID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'InternalPID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'Episode' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'VisitClass' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'BillAcc' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'BillStatus' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], 'ArchivedDate'=> ['type' => 'DATETIME', 'null' => true], 'DelDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('InternalPVID', true); $this->forge->createTable('patvisit'); // patvisitadt $this->forge->addField([ 'PVADTID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'InternalPVID'=> ['type' => 'INT', 'constraint' => 11, 'null' => true], 'Code' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'LocationID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'AttDoc' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'ReffDoc' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'AdmDoc' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CnsDoc' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], 'ArchivedDate'=> ['type' => 'DATETIME', 'null' => true], 'DelDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PVADTID', true); $this->forge->createTable('patvisitadt'); // patvisitlog $this->forge->addField([ 'PatVisLogID'=> ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'TblName' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'RecID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'FldName' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'FldValuePrev'=> ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'UserID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'SiteID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'DIDType' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'DID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'MachineID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'SessionID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'AppID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'ProcessID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'WebPageID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'EventID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'ActivityID' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'Reason' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'LogDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('PatVisLogID', true); $this->forge->createTable('patvisitlog'); // race $this->forge->addField([ 'SiteID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CodingSysID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'RaceID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'Race' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('RaceID', true); $this->forge->createTable('race'); // religion $this->forge->addField([ 'SiteID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'CodingSysID' => ['type' => 'INT', 'constraint' => 11, 'null' => true], 'ReligionID' => ['type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true], 'Religion' => ['type' => 'VARCHAR', 'constraint' => 255, 'null' => true], 'CreateDate' => ['type' => 'DATETIME', 'null' => true], 'EndDate' => ['type' => 'DATETIME', 'null' => true], ]); $this->forge->addKey('ReligionID', true); $this->forge->createTable('religion'); } public function down() { $this->forge->dropTable('country', true); $this->forge->dropTable('ethnic', true); $this->forge->dropTable('patatt', true); $this->forge->dropTable('patcom', true); $this->forge->dropTable('patdiag', true); $this->forge->dropTable('patidt', true); $this->forge->dropTable('patient', true); $this->forge->dropTable('patreglog', true); $this->forge->dropTable('patrelation', true); $this->forge->dropTable('patvisit', true); $this->forge->dropTable('patvisitadt', true); $this->forge->dropTable('patvisitlog', true); $this->forge->dropTable('race', true); $this->forge->dropTable('religion', true); } }