This is a common question that asked by newbie PHP devs. and it’s also important as well.

composer update will update your dependencies as they are specified in composer.json

For example, if you require this package as a dependency:

"guzzlehttp/guzzle": "6.3.*",

and you have actually installed the 6.3.1 version of this package, running composer update will cause an upgrade of this package (for example to 6.3.2, if it’s already been released)

in detail composer update will:

  • Read composer.json

composer install

composer install will not update anything; it will just install all the dependencies as specified in the composer.lock file

In detail:

  • Check if composer.lock file exists (if not, run composer-update and create it)

When to install and when to update

  • composer update is mostly used in the ‘development phase’, to upgrade our project packages according to what we have specified in the composer.json file,

So these are the overall differentiation b/w composer update and install.