Search code examples
sqlsql-servert-sqlcakephpcakephp-2.4

Using CakePHP to insert rows into a table with one IDENTITY column only


In an existing post (link below) I already know how to insert a row into a table with one identity column for Microsoft SQL Server.

Inserting rows into a table with one IDENTITY column only

and now I want to use CakePHP to do the same. However when I try the following, the record will not be saved.

$this -> MyModel -> create();
if ($this -> MyModel -> save()) {
    $this -> log('Record is saved', 'debug');
} else {
    // Always run the following
    $this -> log('Record is not saved', 'debug');
}

What would be the CakePHP way to save such record into the table?

The table schema for MyModel is below:

CREATE TABLE [dbo].[my_models] (
    [id] INT NOT NULL PRIMARY KEY IDENTITY
)

Solution

  • For demonstration purposes the current model is written as '__THE_CURRENT_MODEL__' which is, of course, not a proper CakePHP model name. Duh!

        public function add() {
            if( $this->request->is('post') ){
                $this->__THE_CURRENT_MODEL__->create();
                if( $this->__THE_CURRENT_MODEL__->save(
                    array(
                        '__THE_CURRENT_MODEL__' => array( 'id' => 'NULL' )
                    )
                ) ){
                    $this->Flash->success(__('The __current_model__ has been saved.'));
                    return $this->redirect( array( 'action' => 'index' ) );
                }else{
                    $this->Flash->error(__('The __current_model__ could not be saved. Please, try again.'));
                }
            }
        }
    

    As you should note - the value 'NULL' is not NULL .. which would result in no query at all - the id column is numeric.