Quero inserir um novo campo para a tabela do banco de dados na minha extensão personalizada usando o esquema de atualização seguindo esta publicação , mas recebi um erro dizendo:
[Zend_Db_Statement_Exception]
SQLSTATE[42S02]: Base table or view not found: 1146 Table 'Category Depth.l
ime_eleveniacategory' doesn't exist, query was: DESCRIBE `Category Depth`.`
lime_eleveniacategory`
aqui está o meu código:
namespace Test\TestAgain\Setup;
use Magento\Framework\Setup\UpgradeSchemaInterface;
use Magento\Framework\Setup\ModuleContextInterface;
use Magento\Framework\Setup\SchemaSetupInterface;
class UpgradeSchema implements UpgradeSchemaInterface
{
/**
* {@inheritdoc}
*/
public function upgrade(
SchemaSetupInterface $setup,
ModuleContextInterface $context
) {
$setup->startSetup();
if (version_compare($context->getVersion(), "1.0.0", "<")) {
//Your upgrade script
}
if (version_compare($context->getVersion(), '1.0.1', '<')) {
$tableName = $setup->getTable('lime_eleveniacategory');
if ($setup->getConnection()->isTableExists($tableName) == true) {
$connection = $setup->getConnection();
$connection->addColumn(
$tableName,
'category_depth',
['type' => \Magento\Framework\DB\Ddl\Table::TYPE_INTEGER,'nullable' => false, 'afters' => 'category_name'],
'Category Depth'
);
}
}
$setup->endSetup();
}
}
magento2
database
upgradeschema
Shell Suite
fonte
fonte
Respostas:
Você também pode obter mais detalhes aqui, tabela Atualizar banco de dados
fonte
Mais uma coisa a fazer aqui. Atualizar
module.xml
versão. E atualize a instalação, reindexe e exclua o cache. Vai funcionar.fonte
Para adicionar múltiplas colunas
fonte
Eu tentei isso
OU
Nota: Se você enfrentar algum problema, pode ser devido ao módulo que você já instalou. Como você sabe, se o módulo já estiver instalado, o comando setup: upgrade não instala o esquema. Você precisará examinar sua tabela setup_module, excluir seu módulo da tabela e executar novamente o comando php bin / magento setup: upgrade.
fonte