doushai4890 2014-08-21 13:48
浏览 25
已采纳

尝试将实体与另一个实体关联会导致插入

I am new to Doctrine 2 and I am trying to Create a new Transaction then try to see if that Transaction belong to any pre-existing Category. If it does then associate this Transaction to the given Category

When I run the code below at the highlighted point it should associate the Transaction to a Category. But I get the following Error which then tells me that the code is trying to add a new Category... but what I need it to do is to add a new reference in the table transactions_category (see the Picture below to see this table schema) and NOT a new Category... as that one already exists....

Its a ManyToMany association

How can I associate the two entities properly?

enter image description here

The Error:

An exception occurred while executing 'INSERT INTO category (name) VALUES (?)' with params ["Gyms"]:

SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry 'Gyms' for key 'name'

The Code

   // Get all Categories
$categoryList = $this->getEntityManager()->getRepository('Bnk\Entity\Category')->findAll();

foreach ( $CSVData as $transactionRaw )
{
    $transaction = new \Bnk\Entity\Transaction();
    $transaction->setDescription( $transactionRaw[ "description" ] );
    $transaction->setValue( $transactionRaw[ "value" ] );
    $transaction->setDate( $transactionRaw[ "date" ] );
    $transaction->setAccountnumber( $transactionRaw[ "accountNumber" ] );
    $transaction->setAccountname( $transactionRaw[ "accountName" ] );

    $this->getEntityManager()->persist( $transaction );

    // Check if there are categories
    if(!empty($categoryList))
    {
        // Loop through the categories
        /** @var \Bnk\Entity\Category $category */
        foreach( $categoryList as $category )
        {
            if( !$regexEntities = $category->getCategoryregex() )

                // Loop through the regex of a given category
                /** @var \Bnk\Entity\CategoryRegex $regex */
                foreach( $regexEntities as $regex )
                {
                    if(strpos($transactionRaw["description"],$regex->getName()) !== false)
                    {

                        // I am trying to associate the Transaction to this Category
                        // Instead this is adding the Category as if it was a new one
                        $transaction->addCategory($category);
                    }
                }
            }
        }

   $this->getEntityManager()->flush();
   $this->getEntityManager()->clear();
}
  • 写回答

1条回答 默认 最新

  • dsx666666 2014-08-21 14:42
    关注

    Try to persist your transaction and flush before adding category :

    $this->getEntityManager()->persist( $transaction );
    $this->getEntityManager()->flush();
    
    //add category
    $transaction->addCategory($category);
    $this->getEntityManager()->persist( $transaction );
    $this->getEntityManager()->flush();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 python天天向上类似问题,但没有清零
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 C#调用python代码(python带有库)
  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)