在foreach循环更新实体

问题描述 投票:0回答:1

我需要检查,如果在阵列ID在我的数据库中,如果确实我需要把一些“标志”中的一列,但我有它的问题。

$ch = curl_init();
    curl_setopt($ch, CURLOPT_URL,$url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
    curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);

    curl_setopt($ch, CURLOPT_USERPWD, "$login:$password");
    $fields = curl_exec($ch);

    $reader = Reader::createFromString($fields, 'r')
        ->setDelimiter(',');

    $records = $reader->getRecords(['id_pr']);

    foreach ($records as $offset => $record) {
        $product = $this->productsRepository->findOneBy(['id_pr' => $record['id_pr']]);

This is where i need to update my DB, for each record i need to update 
column 'flag' by eg. '1' but i dont know how :(

    }
    curl_close($ch);

我曾尝试类似$产品 - > setFlag(1);但我不能调用setter方法或者getter方法

它给我的错误:对空调用一个成员函数setFlag()

这是我的产品实体的样子:

class Products
{    

/**
 * @ORM\Column(type="integer")
 */
private $id_pr;
/**
 * @ORM\Column(type="integer", nullable=true)
 */
private $flag;

public function getIdPr(): ?int
{
    return $this->id_pr;
}

public function setIdPr(int $id_pr): self
{
    $this->id_pr = $id_pr;

    return $this;
}

/**
 * @return mixed
 */
public function getFlag()
{
    return $this->flag;
}

/**
 * @param mixed $flag
 */
public function setFlag($flag): void
{
    $this->flag = $flag;
}
php symfony doctrine symfony4
1个回答
0
投票
foreach ($records as $offset => $record) {
    $product = $this->productsRepository->findOneBy(['id_pr' => $record['id_pr']]);
    if($product) {
        $product->setFlag($flagValue);
        $this->getDoctrine()->getManager()->flush(); //I'm assuming that you're in a controller
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.