我想在更新对象时“清空”ObjectStorage:
它是 TYPO3 4.6,带有 Extbase 扩展,允许您在前端显示/添加/编辑/删除数据集。乍一看一切看起来都不错。
我有一个字段引用另一张表:
TCA:
'partner' => array(
'exclude' => 0,
'label' => 'LLL:EXT:toco3_marketingdb/Resources/Private/Language/locallang_db.xlf:tx_toco3marketingdb_domain_model_firma.partner',
'config' => array(
'type' => 'select',
'size' => 5,
'foreign_table' => 'tx_toco3marketingdb_domain_model_partner',
'foreign_table_where' => 'ORDER BY tx_toco3marketingdb_domain_model_partner.partnerpkey',
'minitems' => 0,
'maxitems' => 20,
),
),
Model:
/**
* Partner
*
* @var Tx_Extbase_Persistence_ObjectStorage<Tx_Toco3Marketingdb_Domain_Model_Partner>
* @lazy
*/
protected $partner;
/**
* Sets the partner
*
* @param Tx_Extbase_Persistence_ObjectStorage<Tx_Toco3Marketingdb_Domain_Model_Partner> $partner
* @return void
*/
public function setPartner(Tx_Extbase_Persistence_ObjectStorage $partner) {
$this->partner = $partner;
}
控制器:
$partner = new Tx_Extbase_Persistence_ObjectStorage();
if (count($partnerarr) > 0){
foreach($partnerarr as $p){
$partner->attach( $this->partnerRepository->findByUid($p));
}
}
$organisation = $this->organisationRepository->findByUid($uid)
$organisation->setPartner($partner);
只要对象存储中存在对象,此操作就有效。所以我可以添加/删除/更改关系。但是,当 $partnerarr 为空且未附加任何对象且分配了空的 Tx_Extbase_Persistence_ObjectStorage 时,旧值不会被“删除”。我还尝试分配 null 或“”,但出现错误,因为需要 ObjectStorage。如果我分配空的 ObjectStorage,我不会收到错误,但旧值仍然保留:(
任何想法?
谢谢
基督教