As of migrations 4.3 there is a new migrations backend that uses CakePHP’s
database abstractions and ORM. In 4.4, the builtin
backend became the
default backend. Longer term this will allow for phinx to be
removed as a dependency. This greatly reduces the dependency footprint of
migrations.
Your migrations shouldn’t have to change much to adapt to the new backend. The migrations backend implements all of the phinx interfaces and can run migrations based on phinx classes. If your migrations don’t work in a way that could be addressed by the changes outlined below, please open an issue, as we’d like to maintain as much compatibility as we can.
If your migrations are using the AdapterInterface
to fetch rows or update
rows you will need to update your code. If you use Adapter::query()
to
execute queries, the return of this method is now
Cake\Database\StatementInterface
instead. This impacts fetchAll()
,
and fetch()
:
// This
$stmt = $this->getAdapter()->query('SELECT * FROM articles');
$rows = $stmt->fetchAll();
// Now needs to be
$stmt = $this->getAdapter()->query('SELECT * FROM articles');
$rows = $stmt->fetchAll('assoc');
Similar changes are for fetching a single row:
// This
$stmt = $this->getAdapter()->query('SELECT * FROM articles');
$rows = $stmt->fetch();
// Now needs to be
$stmt = $this->getAdapter()->query('SELECT * FROM articles');
$rows = $stmt->fetch('assoc');
The new backend is enabled by default. If your migrations contain errors when
run with the builtin backend, please open an issue. You can also switch back
to the phinx
backend through application configuration. Add the
following to your config/app.php
:
return [
// Other configuration.
'Migrations' => ['backend' => 'phinx'],
];