$this->createIndex('idx-parent_id', '{{%category}}', 'parent_id');
$this->db->createCommand('SET foreign_key_checks=0')->execute();
$this->addForeignKey('fk-parent_id', '{{%category}}', 'parent_id', '{{%category}}', 'id', 'CASCADE');
$this->db->createCommand('SET foreign_key_checks=1')->execute();
так же перед установкой ключа надо отключить, а затем включить проверку внешнего ключа.
$this->db->createCommand('SET foreign_key_checks=0')->execute();
$this->addForeignKey('fk-parent_id', '{{%category}}', 'parent_id', '{{%category}}', 'id', 'CASCADE');
$this->db->createCommand('SET foreign_key_checks=1')->execute();