safeCreateTable('rescue_animal_field_value', [ 'id' => $this->primaryKey(), 'animal_id' => $this->integer()->notNull(), 'field_definition_id' => $this->integer()->notNull(), 'value_text' => $this->text()->null(), 'value_json' => $this->text()->null(), 'created_at' => $this->dateTime()->null(), 'updated_at' => $this->dateTime()->null(), ]); $this->safeCreateIndex('ux_rescue_animal_field_value_unique', 'rescue_animal_field_value', ['animal_id', 'field_definition_id'], true); $this->safeCreateIndex('idx_rescue_animal_field_value_animal', 'rescue_animal_field_value', 'animal_id', false); $this->safeCreateIndex('idx_rescue_animal_field_value_definition', 'rescue_animal_field_value', 'field_definition_id', false); $this->safeAddForeignKey( 'fk_rescue_animal_field_value_animal', 'rescue_animal_field_value', 'animal_id', 'rescue_animal', 'id', 'CASCADE', 'CASCADE' ); if ($this->db->getSchema()->getTableSchema('rescue_field_definition', true) !== null) { $this->safeAddForeignKey( 'fk_rescue_animal_field_value_definition', 'rescue_animal_field_value', 'field_definition_id', 'rescue_field_definition', 'id', 'CASCADE', 'CASCADE' ); } } public function safeDown() { $this->safeDropTable('rescue_animal_field_value'); } }