Estou tentando adicionar nova coluna à tabela existente no magento2
<?php
namespace Vendor\Module\Setup;
use Magento\Framework\Setup\InstallSchemaInterface;
use Magento\Framework\Setup\ModuleContextInterface;
use Magento\Framework\Setup\SchemaSetupInterface;
/**
* @codeCoverageIgnore
*/
class InstallSchema implements InstallSchemaInterface
{
/**
* {@inheritdoc}
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
*/
public function install(SchemaSetupInterface $setup, ModuleContextInterface $context)
{
$installer = $setup;
$installer->startSetup();
$eavTable = $installer->getTable('eav_attribute');
$columns = [
'my_column' => [
'type' => \Magento\Framework\DB\Ddl\Table::TYPE_INTEGER,
'length' => '1',
'nullable' => false,
'comment' => 'Description of my column',
],
];
$connection = $installer->getConnection();
foreach ($columns as $name => $definition) {
$connection->addColumn($eavTable, $name, $definition);
}
$installer->endSetup();
}
}
php bin / magento setup: atualização
Nada acontece
Atualização 1.
Se eu entender claramente o objetivo, o InstallSchema será executado apenas quando não houver valores na tabela de instalação. Se o seu módulo já estiver instalado no sistema - você precisará fazer alterações no UpgradeSchema. Isso porque meu arquivo não foi executado. Quando o renomeei para atualizar e fazer as alterações necessárias - tudo começou a funcionar corretamente
fonte
Exclua a entrada do módulo da tabela 'setup_module' e execute o comando php bin / magento setup: upgrade. Vai funcionar.
fonte
você pode criar um script e na pasta dbscripts e executar esse arquivo no terminal ou no navegador da web.
por exemplo, salve o arquivo,
pub/dbscripts/filename.php
cole este código e altere de acordo com sua exigênciaexecute este arquivo no navegador como
fonte