2017-01-06 3 views
0

CakePHP Vertion: 3.3.11CakePHP 3 counterCache pas mise à jour sur supprimer avec belongsToMany SelfJoinTable

counterCache travaillant sur la méthode d'ajout, mais ne fonctionne pas sur la méthode de suppression.

SentenceTable

$this->belongsToMany('Sentences', [ 
     'foreignKey' => 'second_sentence_id', 
     'targetForeignKey' => 'sentence_id', 
     'joinTable' => 'sentences_sentences' 
    ]); 
    $this->belongsToMany('SecondSentences', [ 
     'className' => 'Sentences', 
     'foreignKey' => 'sentence_id', 
     'targetForeignKey' => 'second_sentence_id', 
     'joinTable' => 'sentences_sentences' 
    ]); 

SentencesSentencesTable

$this->belongsTo('Sentences', [ 
     'foreignKey' => 'sentence_id', 
     'joinType' => 'INNER' 
    ]); 
    $this->belongsTo('SecondSentences', [ 
     'className'=>'Sentences', 
     'foreignKey' => 'second_sentence_id', 
     'joinType' => 'INNER' 
    ]); 

    $this->addBehavior('CounterCache', ['Sentences' => ['ver_count']]); 

SentencesController Ajouter la mise à jour de la méthode ver_count

$sentence = $this->Sentences->get($this->request->data['id']); 
$sentence = $this->Sentences->patchEntity($sentence, $this->request->data); 
      $this->Sentences->SecondSentences->saveStrategy('append'); 
      $this->Sentences->save($sentence); 

SentencesController supprimer la méthode de mise à jour ne ver_count

$sentence = $this->Sentences->SecondSentences->get($this->request->data['id'],['contain'=>['Sentences']]); 
if ($sentence->user_id == $this->Auth->user('id')) { 
    $this->Sentences->SecondSentences->delete($sentence); 
    $sentences = $this->Sentences->get($sentence->sentences[0]->id,['contain'=>['SecondSentences']]); 

// NOW I AM USING BELOW CODE FOR UPDATING VER_COUNT. 
    $this->Sentences->updateAll(['ver_count'=>count($sentences->second_sentences)], ['id'=>$sentence->sentences[0]->id]); 
} 
+0

postez votre méthode d'ajout et de suppression aussi ... afin que quelqu'un puisse vous aider. –

Répondre

0

Comment sont supprimés vos enregistrements.Comme mentionné dans la documentation de CakePHP (CounterCache):

The counter will not be updated when you use deleteAll(), or execute SQL you have written. 

Et:

The CounterCache behavior works for belongsTo associations only. 

Il suffit de confirmer à ce sujet en premier.

+0

Oui c'est mon association de faute est raison mais travaille sur la méthode add avec l'association belgongsToMany. – Kani