0
我有兩個實體template
和div
其代碼如下:(一產生就通過控制檯自動)的Symfony2:實體問題
<?php
namespace Tun\PublicBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* Tun\PublicBundle\Entity\Template
*
* @ORM\Table(name="template")
* @ORM\Entity
*/
class Template
{
/**
* @var integer $id
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var string $name
*
* @ORM\Column(name="name", type="string", length=255, nullable=true)
*/
private $name;
/**
* @var integer $nbreDiv
*
* @ORM\Column(name="nbre_div", type="integer", nullable=false)
*/
private $nbreDiv;
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Set name
*
* @param string $name
*/
public function setName($name)
{
$this->name = $name;
}
/**
* Get name
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Set nbreDiv
*
* @param integer $nbreDiv
*/
public function setNbreDiv($nbreDiv)
{
$this->nbreDiv = $nbreDiv;
}
/**
* Get nbreDiv
*
* @return integer
*/
public function getNbreDiv()
{
return $this->nbreDiv;
}
}
格:
<?php
namespace Tun\PublicBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* Tun\PublicBundle\Entity\Div
*
* @ORM\Table(name="div")
* @ORM\Entity
*/
class Div
{
/**
* @var integer $id
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var integer $hauteur
*
* @ORM\Column(name="hauteur", type="integer", nullable=false)
*/
private $hauteur;
/**
* @var integer $largeur
*
* @ORM\Column(name="largeur", type="integer", nullable=false)
*/
private $largeur;
/**
* @var integer $ind
*
* @ORM\Column(name="ind", type="integer", nullable=true)
*/
private $ind;
/**
* @var string $emplacement
*
* @ORM\Column(name="emplacement", type="string", length=255, nullable=false)
*/
private $emplacement;
/**
* @var Template
*
* @ORM\ManyToOne(targetEntity="Template")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="template", referencedColumnName="id")
* })
*/
private $template;
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Set hauteur
*
* @param integer $hauteur
*/
public function setHauteur($hauteur)
{
$this->hauteur = $hauteur;
}
/**
* Get hauteur
*
* @return integer
*/
public function getHauteur()
{
return $this->hauteur;
}
/**
* Set largeur
*
* @param integer $largeur
*/
public function setLargeur($largeur)
{
$this->largeur = $largeur;
}
/**
* Get ind
*
* @return integer
*/
public function getInd()
{
return $this->ind;
}
/**
* Set ind
*
* @param integer $ind
*/
public function setInd($ind)
{
$this->ind = $ind;
}
/**
* Get largeur
*
* @return integer
*/
public function getLargeur()
{
return $this->largeur;
}
/**
* Set emplacement
*
* @param string $emplacement
*/
public function setEmplacement($emplacement)
{
$this->emplacement = $emplacement;
}
/**
* Get emplacement
*
* @return string
*/
public function getEmplacement()
{
return $this->emplacement;
}
/**
* Set template
*
* @param Tun\PublicBundle\Entity\Template $template
*/
public function setTemplate(\Tun\PublicBundle\Entity\Template $template)
{
$this->template = $template;
}
/**
* Get template
*
* @return Tun\PublicBundle\Entity\Template
*/
public function getTemplate()
{
return $this->template;
}
}
現在這裏的問題是,我希望創建一個模板然後一個div,所以我這樣繼續:
$template= new Template();
$template->setName($name);
$template->setNbreDiv($nbre_div);
$em = $this->getDoctrine()->getEntityManager();
$em->persist($template);
$em->flush();
$d=new Div();
$d->setHauteur(100);
$d->setLargeur(100);
$d->setEmplacement("Gauche");
$d->setInd(1);
$d->setTemplate($template);
$em = $this->getDoctrine()->getEntityManager();
$em->persist($d);
$em->flush();
我得到以下錯誤:
SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'div (hauteur, largeur, ind, emplacement, template) VALUES (100, 100, 1, 'Gauche'' at line 1
希望我把所有的東西,感謝您的幫助提前。我花了整整一天的時間來嘗試所有我想到的組合......
我不知道我應該高興還是不好意思:■謝謝很多反正 –
@MarouaGasmi不要不好意思!我每天都在使用MySQL,直到今天,從來不知道關於DIV的關鍵字。根據您發佈的錯誤消息,剛剛有預感。無論如何,很高興你有它的底部! –