[英]Notice: Array to string conversion in Symfony
我的代碼有問題。 我有一個實體:
namespace CP\API\Entity;
use CP\Model\Configuration;
use CP\Model\Content;
use CP\Model\Language;
use CP\Model\MenuTranslation;
use CP\RestBundle\Model\Locator;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;
/**
* @ORM\HasLifecycleCallbacks()
* @ORM\Table(name="cp_menu")
* @ORM\Entity(repositoryClass="CP\API\Repository\MenuRepository")
*/
class Menu
{
/**
* @var int
*
* @ORM\Id()
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @var Locator
*
* @ORM\ManyToOne(targetEntity="Locator", cascade={"persist"})
* @ORM\JoinColumn(name="locator_id", referencedColumnName="id", onDelete="SET NULL")
*/
protected $locator;
/**
* Parent Menu
*
* @ORM\ManyToOne(targetEntity="Menu", inversedBy="children", cascade={"persist"})
* @ORM\JoinColumn(name="parent_id", referencedColumnName="id", onDelete="SET NULL")
*/
protected $parent;
/**
* @ORM\ManyToOne(targetEntity="DataPool",cascade={"persist"})
* @ORM\JoinColumn(name="datapool_id", referencedColumnName="id", onDelete="SET NULL")
*/
protected $dataPool;
/**
* @ORM\ManyToOne(targetEntity="Product")
* @ORM\JoinColumn(name="product_id", referencedColumnName="id", nullable=true)
*/
protected $product;
/**
* @var string
*
* @ORM\Column(name="identifier", type="string", nullable=true)
*/
protected $identifier;
/**
* @var array
*
* @ORM\Column(name="data", type="text", length=65535)
*/
protected $data = [];
/**
* @var boolean
*
* @ORM\Column(name="display", type="boolean")
*/
protected $display;
/**
* @var boolean
*
* @ORM\Column(name="display_children", type="boolean")
*/
protected $displayChildren;
/**
* @var string
*
* @ORM\Column(name="path_string", type="string", nullable=false)
*/
protected $pathString;
/**
* @var int
*
* @ORM\Column(name="priority", type="integer")
*/
protected $priority;
/**
* @var int
*
* @ORM\Column(name="status", type="smallint", length=1)
*/
protected $status;
/**
* @var boolean
*
* @ORM\Column(name="produce", type="boolean")
*/
protected $produce = false;
/**
* @var int
*
* @ORM\Column(name="inheritance_priority", type="integer", nullable=false, options={"default" : 0})
*/
protected $inheritancePriority;
/** @var DateTime */
protected $creation;
/** @var DateTime */
protected $modification;
/**
* @return int
*/
public function getId(): int
{
return $this->id;
}
/**
* @param int $id
*/
public function setId(int $id): void
{
$this->id = $id;
}
/**
* @return Locator
*/
public function getLocator(): Locator
{
return $this->locator;
}
/**
* @param Locator $locator
*/
public function setLocator(Locator $locator): void
{
$this->locator = $locator;
}
/**
* @return mixed
*/
public function getParent()
{
return $this->parent;
}
/**
* @param mixed $parent
*/
public function setParent($parent): void
{
$this->parent = $parent;
}
/**
* @return mixed
*/
public function getDataPool()
{
return $this->dataPool;
}
/**
* @param mixed $dataPool
*/
public function setDataPool($dataPool): void
{
$this->dataPool = $dataPool;
}
/**
* @return mixed
*/
public function getProduct()
{
return $this->product;
}
/**
* @param mixed $product
*/
public function setProduct($product): void
{
$this->product = $product;
}
/**
* @return string
*/
public function getIdentifier(): string
{
return $this->identifier;
}
/**
* @param string $identifier
*/
public function setIdentifier(string $identifier): void
{
$this->identifier = $identifier;
}
/**
* @return array
*/
public function getData(): array
{
return $this->data;
}
/**
* @param array $data
*/
public function setData(array $data)
{
$this->data = $data;
}
/**
* @return bool
*/
public function isDisplay(): bool
{
return $this->display;
}
/**
* @param bool $display
*/
public function setDisplay(bool $display): void
{
$this->display = $display;
}
/**
* @return bool
*/
public function isDisplayChildren(): bool
{
return $this->displayChildren;
}
/**
* @param bool $displayChildren
*/
public function setDisplayChildren(bool $displayChildren): void
{
$this->displayChildren = $displayChildren;
}
/**
* @return string
*/
public function getPathString(): string
{
return $this->pathString;
}
/**
* @param string $pathString
*/
public function setPathString(string $pathString): void
{
$this->pathString = $pathString;
}
/**
* @return int
*/
public function getPriority(): int
{
return $this->priority;
}
/**
* @param int $priority
*/
public function setPriority(int $priority): void
{
$this->priority = $priority;
}
/**
* @return int
*/
public function getStatus(): int
{
return $this->status;
}
/**
* @param int $status
*/
public function setStatus(int $status): void
{
$this->status = $status;
}
/**
* @return bool
*/
public function isProduce(): bool
{
return $this->produce;
}
/**
* @param bool $produce
*/
public function setProduce(bool $produce): void
{
$this->produce = $produce;
}
/**
* @return int
*/
public function getInheritancePriority(): int
{
return $this->inheritancePriority;
}
/**
* @param int $inheritancePriority
*/
public function setInheritancePriority(int $inheritancePriority): void
{
$this->inheritancePriority = $inheritancePriority;
}
/**
* @return DateTime
*/
public function getCreation(): DateTime
{
return $this->creation;
}
/**
* @param DateTime $creation
*/
public function setCreation(DateTime $creation): void
{
$this->creation = $creation;
}
/**
* @return DateTime
*/
public function getModification(): DateTime
{
return $this->modification;
}
/**
* @param DateTime $modification
*/
public function setModification(DateTime $modification): void
{
$this->modification = $modification;
}
}
和我在MenuRepository
方法:
/**
* @param Menu $menu
* @return mixed
*/
public function addMenu(Menu $menu)
{
try {
$this->getEntityManager()->beginTransaction(); // suspend auto-commit
$this->getEntityManager()->persist($menu);
$this->getEntityManager()->flush($menu);
$this->getEntityManager()->commit();
$this->getEntityManager()->detach($menu);
return $menu;
} catch (\Exception $e) {
throw new RepositoryException($e->getMessage());
}
當我向數據庫添加新記錄時,出現錯誤:
在 MenuRepository.php 第 79 行:
注意:數組到字符串的轉換
第 79 行是:
throw new RepositoryException($e->getMessage());
我添加新記錄的命令代碼:
$menuData = new Menu();
$menuData->setStatus(1);
$menuData->setData([]);
$dataPool = new DataPoolEntity();
$dataPool->setIsReadonly(true);
$dataPool->setName("qwerty");
$dataPool->setDescription("tester");
$dataPool->setChildren(null);
$menuData->setDataPool($dataPool);
$menuData->setPathString('qwertty');
$menuData->setPriority(1);
$menuData->setDisplayChildren(true);
$menuData->setDisplay(true);
$menuData->setIdentifier("qwery");
$menuData->setInheritancePriority(1);
在我的 var.log 我有這條消息:
[2019-12-21T20:35:49.313897+01:00] console.ERROR: 運行命令“sdk:menu:create -vvvvv”時拋出錯誤。 消息:“注意:數組到字符串轉換”{“異常”:“[對象](CP\\Model\\Exception\\RepositoryException(代碼:0):注意:數組到字符串轉換在 C:\\Users\\rever\\PhpstormProjects\\cp -base\\vendor\\cp\\web-core\\src\\Model\\Repository\\MenuRepository.php:79)","command":"sdk:menu:create -vvvvv","message":"注意:數組到字符串的轉換"} []
我不知道我的代碼有什么問題:(幾個小時以來我一直在尋找錯誤的原因,但我無法處理它,這就是我寫的原因。我已經嘗試過嚴格地添加一些值,但它會給出同樣的問題。
您的數據在您的實體中定義如下:
/**
* @var array
*
* @ORM\Column(name="data", type="text", length=65535)
*/
protected $data = [];
但是在您的@var
您指定了array
,因此您可以將列類型更改為array
如下所示:
/**
*
* @ORM\Column(name="data", type="array")
*/
protected $data = [];
這將產生帶有注釋“(DC2Type:array)”的長文本字段,因此 Doctrine 知道如何處理它。 它將存儲一個序列化的數組。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.