У меня есть проблема сучения manyToMany SQLSTATE [HY000]: Общая ошибка: 1005 Не удается создать таблицу (Errno: 150)
/**
* @package Entity
* @ORM\Entity
* @ORM\Table(name="r_country")
*/
class RCountry {
/**
* @ORM\Column(type="string", length=2)
* @ORM\Id
*/
protected $id;
...
/**
*
* @ORM\ManyToMany(targetEntity="RLanguage")
* @ORM\JoinTable(name="prohibited_language_display",
* joinColumns={@ORM\JoinColumn(name="country_id", referencedColumnName="id", onDelete="CASCADE")},
* inverseJoinColumns={@ORM\JoinColumn(name="language_id", referencedColumnName="id", onDelete="CASCADE")}
* )
*
*/
protected $prohibitedLanguageDisplay;
...
}
/**
* @package Entity
* @ORM\Entity
* @ORM\Table(name="r_language")
*/
class RLanguage
{
/**
* @ORM\Column(type="string", length=20)
* @ORM\Id
*
*/
protected $id;
...
}
я пытаюсь сделать ManyToMany отношения с доктриной, но когда я сделать обновление стреляет сообщение об ошибке
[Doctrine\DBAL\Exception\DriverException]
An exception occurred while executing 'ALTER TABLE prohibited_language_display ADD CONSTRAINT FK_77B02D13F92F3E70 FOREIGN KEY (country_id) REFERENCES r_country (id) ON DELETE CASCADE':
SQLSTATE[HY000]: General error: 1005 Can't create table 'database.#sql-498_8797' (errno: 150)[Doctrine\DBAL\Driver\PDOException]
SQLSTATE[HY000]: General error: 1005 Can't create table 'database.#sql-498_8797' (errno: 150)
[PDOException]
SQLSTATE[HY000]: General error: 1005 Can't create table 'database.#sql-498_8797' (errno: 150)
это й дампа SQL я получаю
CREATE TABLE prohibited_language_google (country_id VARCHAR(2) NOT NULL, language_id VARCHAR(20) NOT NULL, INDEX IDX_77B02D13F92F3E70 (country_id), INDEX IDX_77B02D1382F1BAF4 (language_id), PRIMARY KEY(country_id, language_id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB; ALTER TABLE prohibited_language_display ADD CONSTRAINT FK_77B02D13F92F3E70 FOREIGN KEY (country_id) REFERENCES r_country (id) ON DELETE CASCADE; ALTER TABLE prohibited_language_google ADD CONSTRAINT FK_77B02D1382F1BAF4 FOREIGN KEY (language_id) REFERENCES r_language (id) ON DELETE CASCADE;
я уже судимый де удалить базу данных и с, создайте новую с доктриной, и все в порядке, но я хочу просто сделать обновление, иначе я потеряю все данные в моей базе данных.
Есть ли кто-нибудь, кто может мне помочь?