Ich möchte ein neues Feld für die Datenbanktabelle in meine benutzerdefinierte Erweiterung mithilfe des Upgrade-Schemas einfügen, indem ich diesem Beitrag folge , aber es wurde eine Fehlermeldung angezeigt:
[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`
Hier ist mein 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
Shell Suite
quelle
quelle
Antworten:
Weitere Informationen finden Sie auch hier in der Tabelle "Datenbank aktualisieren"
quelle
Noch etwas zu tun.
module.xml
Version aktualisieren . Aktualisieren Sie das Setup, indizieren Sie den Cache neu und löschen Sie ihn. Es wird klappen.quelle
Hinzufügen mehrerer Spalten
quelle
Ich habe es versucht
ODER
Hinweis: Wenn Sie auf ein Problem stoßen, kann dies an dem Modul liegen, das Sie bereits installiert haben. Wie Sie wissen, installiert der Befehl setup: upgrade das Schema nicht, wenn das Modul bereits installiert ist. Sie müssen in Ihre setup_module-Tabelle schauen, Ihr Modul aus der Tabelle löschen und den Befehl php bin / magento setup: upgrade erneut ausführen.
quelle