【问题标题】:doctrine - Inserting records in many to many relationship table教义 - 在多对多关系表中插入记录
【发布时间】:2012-02-29 17:40:17
【问题描述】:

我有两个模型PropertyAmenity,它们之间的关系是多对多的。参考类是PropertyAmenity,当我想将单个记录插入一个模型时,这对我来说很容易。

插入Property

$property = new Property();
$property->serial = 'SER09088';
$property->title = 'Some title';
$property->save();

并且将记录插入到 Amenity 中

$amenity = new Amenity();
$amenity->name = 'Swimming Pool';
$amenity->save();

我想要做的是将现有设施添加到Property,其记录保存在参考类PropertyAmenity 中,例如类似的东西。

$property = new Property();
$property->serial = 'SER09088';
$property->title = 'Some title';
$property->PropertyAmenity->amenity_id[] = 1;
$property->save();

当我尝试上面的代码时,它给了我以下异常

PropertyAmenity 不支持添加

情况是我从一个表单,一个用户那里收集集体信息。例如,用户输入与Property 相关的所有值,然后从表单中选择现有的Multiple Amenities 并提交。我需要保存属性表中的属性和property_amenity 表中的选定设施,其中包含两列property_idamenity_id,如何在学说中插入这个值?

【问题讨论】:

    标签: php orm doctrine many-to-many


    【解决方案1】:

    经过一番挖掘,我自己找到了解决方案,正如预期的那样,它很容易实现。我唯一要做的改变是。

    从这里

    $property->PropertyAmenity->amenity_id[] = 1;
    

    $property->PropertyAmenity[]->amenity_id = 1;
    $property->PropertyAmenity[]->amenity_id = 3;
    $property->PropertyAmenity[]->amenity_id = 5;
    

    它有效,希望它可以帮助某人:)

    【讨论】:

      猜你喜欢
      • 2021-07-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-11-23
      • 1970-01-01
      相关资源
      最近更新 更多