2017-04-20 336 views
1

我试图创建产品和用户之间的关系。一个用户有许多产品和许多产品=> 1个用户。问题是当我将表格添加到表“产品”列user_id = NULL。为什么user_id列是NULL?

这是我在产品实体关系:

/** 
* @ORM\ManyToOne(targetEntity="AppBundle\Entity\User", inversedBy="products") 
* @ORM\JoinColumn(name="user_id", referencedColumnName="id") 
*/ 
private $user; 

和用户实体:

/** 
* @ORM\OneToMany(targetEntity="AppBundle\Entity\Product", mappedBy="user") 
*/ 
private $products; 

为什么列user_id是总是空?以下是用于坚持产品的代码。

/** 
* @Route("/products/add", name="create_products") 
* @Security("has_role('ROLE_USER') or has_role('ROLE_EDITOR') or has_role('ROLE_ADMIN')") 
* @param Request $request 
* @return \Symfony\Component\HttpFoundation\Response 
*/ 
public function createProductAction(Request $request) 
{ 
    $product = new Product(); 

    $form = $this->createForm(ProductType::class, $product); 

    $form->handleRequest($request); 

    if($form->isSubmitted() && $form->isValid()) { 

     /** @var UploadedFile $file */ 
     $file = $product->getImageForm(); 

      $filename = md5($product->getName()); 

      $file->move(
       $this->get('kernel')->getRootDir() . '/../web/images/products/', 
       $filename 
      ); 


      $product->setImage($filename); 

     $em = $this->getDoctrine()->getManager(); 
     $em->persist($product); 
     $em->flush(); 

     $this->redirectToRoute('products'); 

     return $this->redirectToRoute('products'); 
    } 

    return $this->render('products/create.product.html.twig', array(
     'productForm' => $form->createView() 
    )); 
} 
+0

你是如何保存这些?你的表单/控制器是什么样的? – Chausser

+0

请问您如何坚持这两个实体的代码? – manix

+0

这里是创建产品操作https://pastebin.com/LuxTDLip其实,即时通讯不知道如何保存user_id到控制器 – Vnkat19

回答

0

您还没有在您的Product对象中使用您的setter来设置控制器中的用户。那就是问题所在。

您将需要使用的setter像这样:

$product->setImage($filename); 
$product->setUser($user); 


$em = $this->getDoctrine()->getManager(); 
$em->persist($product); 

上述假设你有一个setter称为setUser。您还需要创建用户或确定用户。

0

您在没有用户的情况下坚持产品。你应该这样做:

$product = new Product(); 
$product->setImage($filename); 
$em = $this->getDoctrine()->getManager(); 

// here you associate the user 
$user = $em->find('\AppBundle\Entity\User', 3); // user with id 3 
$product->setUser($user); 

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