Je veux insérer un nouveau champ pour la table de base de données dans mon extension personnalisée en utilisant le schéma de mise à niveau en suivant ce post , mais j'ai une erreur disant:
[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`
voici mon code:
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
Suite Shell
la source
la source
Réponses:
Vous pouvez également obtenir plus de détails ici, tableau de mise à niveau de la base de données
la source
Encore une chose à faire ici. Mettre à jour la
module.xml
version. Et mettez à niveau la configuration, réindexez et supprimez le cache. Ça va marcher.la source
Pour ajouter plusieurs colonnes
la source
J'ai essayé
OU
Remarque: Si vous rencontrez un problème, cela peut être dû au module que vous avez déjà installé. Comme vous le savez, si le module est déjà installé, la commande setup: upgrade n'installe pas le schéma. Vous devrez examiner votre table setup_module, supprimer votre module de la table et réexécuter la commande setup: upgrade de php bin / magento.
la source