Quiero insertar un nuevo campo para la tabla de la base de datos en mi extensión personalizada usando el esquema de actualización siguiendo esta publicación , pero recibí un error que dice:
[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`
Aquí está mi 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
fuente
fuente
Respuestas:
Puede obtener más detalles aquí también, Actualizar tabla de base de datos
fuente
Una cosa más que hacer aquí. Actualizar
module.xml
versión Y actualice la configuración, reindexe y elimine el caché. Funcionará.fuente
Para agregar columnas múltiples
fuente
Probé esto
O
Nota: Si tiene algún problema, puede deberse al módulo que ya instaló. Como sabe, si el módulo ya está instalado, entonces el comando setup: upgrade no instala el esquema. Deberá examinar su tabla setup_module, eliminar su módulo de la tabla y volver a ejecutar el comando php bin / magento setup: upgrade.
fuente