BadHorsie
BadHorsie

Reputation: 14544

CakePHP - How to check in beforeSave if it's an INSERT or UPDATE

In my model's beforeSave method, how can I check if the save operation is going to be an INSERT or an UPDATE?

I want to add to the model data, but only if it's inserting a new row.

Upvotes: 19

Views: 10380

Answers (3)

Olovskos
Olovskos

Reputation: 45

This is how you would do in Cakephp 4 (in case someone is looking for it)

EDIT it also applies to Cakephp 3 as BadHorsie stated

public function beforeSave(EventInterface $event, EntityInterface $entity, ArrayObject $options)
{
    if ($entity->isNew()) {
       //INSERT
    }else{
       //UPDATE
    }
}

Upvotes: 2

nIcO
nIcO

Reputation: 5001

You can just check in the data if the id exists:

function beforeSave($options = array())
{
  if(empty($this->data[$this->alias]['id']))
  {
    //INSERT
  }
  else
  {
    //UPDATE
  }
}

Upvotes: 23

Sunil kumar
Sunil kumar

Reputation: 771

You can try this

public function beforeSave($options = array()) {

    if($this->id) {
        // Update
    } else {
        // Add
    }
}

Upvotes: 0

Related Questions