Chcę wstawić nowe pole dla tabeli bazy danych do mojego niestandardowego rozszerzenia przy użyciu schematu aktualizacji, postępując zgodnie z tym postem , ale dostałem komunikat o błędzie:
[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`
oto mój kod:
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
źródło
źródło
Odpowiedzi:
Możesz również uzyskać więcej informacji tutaj, tabela bazy danych aktualizacji
źródło
Jeszcze jedna rzecz do zrobienia tutaj. Zaktualizuj
module.xml
wersję. I zaktualizuj konfigurację, wykonaj ponowne indeksowanie i usuń pamięć podręczną. To będzie działać.źródło
Aby dodać wielokrotność kolumn
źródło
Próbowałem tego
LUB
Uwaga: jeśli napotkasz jakikolwiek problem, przyczyną może być moduł, który już zainstalowałeś. Jak wiadomo, jeśli moduł jest już zainstalowany, to polecenie setup: upgrade nie instaluje schematu. Musisz zajrzeć do tabeli setup_module, usunąć moduł z tabeli i ponownie uruchomić komendę php bin / magento setup: upgrade.
źródło