许多人不会坚持

时间:2017-09-02 14:22:53

标签: symfony-3.3

我正在使用PHP框架Symfony 3.3和ORM Doctrine开发一个网站。

我有用户,每个用户都可以提供服务。服务可以由多个用户提供。

除非我想要保留用户的服务列表,否则一切都运行良好。什么都没发生,我没有任何错误。你能看到我的代码中有什么问题吗?

我的MySQL用户表:

CREATE TABLE `user` (
`id_user` INT(11) NOT NULL AUTO_INCREMENT,
`firstname` VARCHAR(255) NOT NULL,
`surname` VARCHAR(255) NOT NULL,
`address` VARCHAR(255) NOT NULL,
`zip` VARCHAR(4) NOT NULL,
`city` VARCHAR(255) NOT NULL,
`phone_number` VARCHAR(12) NULL DEFAULT NULL,
`mobile_number` VARCHAR(12) NULL DEFAULT NULL,
`email` VARCHAR(255) NOT NULL,
`password` VARCHAR(255) NOT NULL,
`birth_date` DATE NOT NULL,
`is_verified` TINYINT(4) NULL DEFAULT NULL,
`id_gender` INT(11) NOT NULL,
PRIMARY KEY (`id_user`),
UNIQUE INDEX `e-mail_UNIQUE` (`email`),
UNIQUE INDEX `id_utilisateur_UNIQUE` (`id_user`),
INDEX `fk_id_gender_idx` (`id_gender`),
CONSTRAINT `fk_id_gender` FOREIGN KEY (`id_gender`) REFERENCES `gender`         (`id_gender`)
)

我的MySQL service_offer表:

CREATE TABLE `service_offer` (
`id_service_offer` INT(11) NOT NULL AUTO_INCREMENT,
`id_user` INT(11) NOT NULL,
`id_service` INT(11) NOT NULL,
PRIMARY KEY (`id_service_offer`),
UNIQUE INDEX `id_user_UNIQUE` (`id_user`),
INDEX `fk_service_idx` (`id_service`),
CONSTRAINT `fk_service` FOREIGN KEY (`id_service`) REFERENCES `service` (`id_service`),
CONSTRAINT `fk_user` FOREIGN KEY (`id_user`) REFERENCES `user` (`id_user`)
)

我的MySQL服务表:

CREATE TABLE `service` (
`id_service` INT(11) NOT NULL AUTO_INCREMENT,
`name` VARCHAR(255) NOT NULL,
`description` VARCHAR(255) NULL DEFAULT NULL,
PRIMARY KEY (`id_service`),
UNIQUE INDEX `id_service_UNIQUE` (`id_service`)
)

我的用户实体的一部分:

 /**
 * @var integer
 *
 * @ORM\Column(name="id_user", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="IDENTITY")
 */
private $idUser;

/**
 * 
 * @ORM\ManyToMany(targetEntity="Service")
 * @ORM\JoinTable(name="service_offer",
 *      joinColumns={@ORM\JoinColumn(name="id_user", referencedColumnName="id_user")},
 *      inverseJoinColumns={@ORM\JoinColumn(name="id_service", referencedColumnName="id_service")}
 *      )
 */
private $services;

function getServices() {
    return $this->services;
}

function setServices($services) {
    $this->services = $services;
    return $this;
}

我的服务实体类:

<?php

namespace AppBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Service
 *
 * @ORM\Table(name="service", uniqueConstraints={@ORM\UniqueConstraint(name="id_service_UNIQUE", columns={"id_service"})}, indexes={@ORM\Index(name="fk_user_idx", columns={"user"})})
 * @ORM\Entity
 */
class Service
{
/**
 * @var string
 *
 * @ORM\Column(name="name", type="string", length=255, nullable=false)
 */
private $name;

/**
 * @var string
 *
 * @ORM\Column(name="description", type="string", length=255, nullable=true)
 */
private $description;

/**
 * @var integer
 *
 * @ORM\Column(name="id_service", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="IDENTITY")
 */
private $idService;



/**
 * Set name
 *
 * @param string $name
 *
 * @return Service
 */
public function setName($name)
{
    $this->name = $name;

    return $this;
}

/**
 * Get name
 *
 * @return string
 */
public function getName()
{
    return $this->name;
}

/**
 * Set description
 *
 * @param string $description
 *
 * @return Service
 */
public function setDescription($description)
{
    $this->description = $description;

    return $this;
}

/**
 * Get description
 *
 * @return string
 */
public function getDescription()
{
    return $this->description;
}

/**
 * Get idService
 *
 * @return integer
 */
public function getIdService()
{
    return $this->idService;
}
}

如果我在控制器中执行此操作,则数据库中不会出现任何内容:

$user->setServices($services);

$em->persist($user);
$em->flush();

此代码:

print_r($services);

返回

Doctrine\Common\Collections\ArrayCollection Object ( [elements:Doctrine\Common\Collections\ArrayCollection:private] => Array ( [0] => AppBundle\Entity\Service Object ( [name:AppBundle\Entity\Service:private] => sdfgsdf [description:AppBundle\Entity\Service:private] => sdfgsdf [idService:AppBundle\Entity\Service:private] => 2 ) ) )

这段代码:

echo $services[0]->getName();

返回:

sdfgsdf

有什么想法吗?

提前致谢! :)

2 个答案:

答案 0 :(得分:1)

你能尝试坚持服务吗?例如:

$user->setServices($services);

$em->persist($user);
$em->persist($services);
$em->flush();

答案 1 :(得分:0)

终于发现了什么问题! :):)

我的“\ src \ AppBundle \ Resources \ config \ doctrine”文件夹中有XML文件,因为我从现有数据库生成了我的实体类。但是,多对多连接不是自动生成的,因此我必须手动添加它。

每次我发布此命令:

php bin/console doctrine:schema:update --force

我知道一切都是最新的。但实际上,Symfony使用的是存储在XML文件中而不是注释中的信息....

所以,我删除了XML文件,再次更新了我的架构,现在它正在运行。我看到Symfony更新了表service_offer并删除了实际上不需要的“id_service_offer”列。