Светильники Symfony2 с ссылками не загружаются (нарушение ограничения) - PullRequest
2 голосов
/ 27 февраля 2012

Я уже несколько часов бьюсь над своими проектами Symfony2.Вот ошибка, которую я получаю:

SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`wpanel_dev`.`sshuser`, CONSTRAINT `FK_612DE3EE18F45C82` FOREIGN KEY (`website_id`) REFERENCES `Website` (`id`))  

Прочитав много ответов, я безуспешно попробовал этот метод:

php app/console doctrine:database:drop --force
php app/console doctrine:database:create
php app/console doctrine:schema:update --force
php app/console doctrine:fixtures:load (with or without --append)

Вот код прибора, который генерирует ошибку ($ new-> setWebsite ($ this-> getReference ('website -'. $ i));)

<?php
namespace WPanel\AdminBundle\DataFixtures\ORM;

use Doctrine\Common\DataFixtures\FixtureInterface;
use WPanel\AdminBundle\Entity\SSHUser;
use Doctrine\Common\Persistence\ObjectManager;
use Doctrine\Common\DataFixtures\AbstractFixture;
use Doctrine\Common\DataFixtures\OrderedFixtureInterface;

class LoadSSHUserData extends AbstractFixture implements OrderedFixtureInterface
{   
    public function getOrder()
    {
        return 5;
    }

    public function load(ObjectManager $manager)
    {

        for($i = 1; $i <= 20; $i++) {
            $new = new SSHUser();
            $new->setUser('sshuser'.$i);
            $new->setPassword('sshuser'.$i);
            $new->setPath('/var/www/website'.$i.'.com');
            $new->setWebsite($this->getReference('website-'.$i));

            $manager->persist($new);
        }

        $manager->flush();
    }
}
?>

Я уверен, что ссылка в порядке.Я использую add / getReference на других классах без проблем.

Спасибо за вашу помощь!

Ответы [ 2 ]

0 голосов
/ 19 марта 2012

Похоже, у вас нет 20 объектов объектов, так как вы используете счетчик $i от 0 до 20.

0 голосов
/ 19 марта 2012

Эта ошибка означает, что в таблице веб-сайта нет записи с таким идентификатором, если я правильно понял.

Либо есть проблема с вашим заказом, либо опечатка в ссылке.

...