Sometimes we need to perform a quick bulk update of a specific product attribute for the whole catalog. But as we know, fetching the whole Product entity takes a lot of resources.
So here’s how to update a single product attribute value without loading the whole Product object.
In this standalone script, which can be placed on the project root and executed as php -f update-attr.php
, I’ll show you how to update the attribute “has_upload_file” for all of the products.
<?php
use Magento\Framework\App\Bootstrap;
require __DIR__ . '/app/bootstrap.php';
$bootstrap = Bootstrap::create(BP, $_SERVER);
$obj = $bootstrap->getObjectManager();
// Set the state. You can also set "adminhtml"
$state = $obj->get('Magento\Framework\App\State');
$state->setAreaCode('frontend');
// Get the first product of a collection
$products = $obj->get('Magento\Catalog\Model\ResourceModel\Product\Collection');
foreach ($products as $p) {
$p->setData('has_upload_file', 0);
$p->getResource()->saveAttribute($p, 'has_upload_file');
}