Ошибка при нажатии на способы оплаты в Magneto
При нажатии на Способы оплаты на странице конфигурации я получаю эту ошибку.
SQLSTATE[42S02]: Base table or view not found: 1146 Table 'photocha_magento64.sales_order_status' doesn't exist
,
запрос был:
SELECT `main_table`.*, `state_table`.`state`, `state_table`.`is_default` FROM `sales_order_status` AS `main_table`
LEFT JOIN `sales_order_status_state` AS `state_table` ON main_table.status=state_table.status WHERE (state_table.state='new') ORDER BY `main_table`.`label` ASC
Трассировка:
#0 /home/photocharms/public_html/lib/Varien/Db/Statement/Pdo/Mysql.php(110): Zend_Db_Statement_Pdo->_execute(Array)
#1 /home/photocharms/public_html/app/code/core/Zend/Db/Statement.php(291): Varien_Db_Statement_Pdo_Mysql->_execute(Array)
#2 /home/photocharms/public_html/lib/Zend/Db/Adapter/Abstract.php(480): Zend_Db_Statement->execute(Array)
#3 /home/photocharms/public_html/lib/Zend/Db/Adapter/Pdo/Abstract.php(238): Zend_Db_Adapter_Abstract->query('SELECT `main_ta...', Array)
#4 /home/photocharms/public_html/lib/Varien/Db/Adapter/Pdo/Mysql.php(504): Zend_Db_Adapter_Pdo_Abstract->query('SELECT `main_ta...', Array)
#5 /home/photocharms/public_html/lib/Zend/Db/Adapter/Abstract.php(737): Varien_Db_Adapter_Pdo_Mysql->query('SELECT `main_ta...', Array)
#6 /home/photocharms/public_html/lib/Varien/Data/Collection/Db.php(740): Zend_Db_Adapter_Abstract->fetchAll('SELECT `main_ta...', Array)
#7 /home/photocharms/public_html/app/code/core/Mage/Core/Model/Resource/Db/Collection/Abstract.php(521): Varien_Data_Collection_Db->_fetchAll('SELECT `main_ta...', Array)
#8 /home/photocharms/public_html/lib/Varien/Data/Collection/Db.php(572): Mage_Core_Model_Resource_Db_Collection_Abstract->getData()
#9 /home/photocharms/public_html/lib/Varien/Data/Collection.php(741): Varien_Data_Collection_Db->load()
#10 /home/photocharms/public_html/app/code/core/Mage/Sales/Model/Order/Config.php(173): Varien_Data_Collection->getIterator()
#11 /home/photocharms/public_html/app/code/core/Mage/Adminhtml/Model/System/Config/Source/Order/Status.php(46): Mage_Sales_Model_Order_Config->getStateStatuses('new')
#12 /home/photocharms/public_html/app/code/core/Mage/Adminhtml/Block/System/Config/Form.php(463): Mage_Adminhtml_Model_System_Config_Source_Order_Status->toOptionArray(false)
#13 /home/photocharms/public_html/app/code/core/Mage/Adminhtml/Block/System/Config/Form.php(229): Mage_Adminhtml_Block_System_Config_Form->initFields(Object(Varien_Data_Form_Element_Fieldset), Object(Mage_Core_Model_Config_Element), Object(Mage_Core_Model_Config_Element))
#14 /home/photocharms/public_html/app/code/core/Mage/Adminhtml/Block/System/Config/Form.php(164): Mage_Adminhtml_Block_System_Config_Form->_initGroup(Object(Varien_Data_Form), Object(Mage_Core_Model_Config_Element), Object(Mage_Core_Model_Config_Element))
#15 /home/photocharms/public_html/app/code/core/Mage/Adminhtml/Block/System/Config/Edit.php(92): Mage_Adminhtml_Block_System_Config_Form->initForm()
#16 /home/photocharms/public_html/app/code/core/Mage/Adminhtml/controllers/System/ConfigController.php(107): Mage_Adminhtml_Block_System_Config_Edit->initForm()
#17 /home/photocharms/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php(418): Mage_Adminhtml_System_ConfigController->editAction()
#18 /home/photocharms/public_html/app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(254): Mage_Core_Controller_Varien_Action->dispatch('edit')
#19 /home/photocharms/public_html/app/code/core/Mage/Core/Controller/Varien/Front.php(172): Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))
#20 /home/photocharms/public_html/app/code/core/Mage/Core/Model/App.php(365): Mage_Core_Controller_Varien_Front->dispatch()
#21 /home/photocharms/public_html/app/Mage.php(684): Mage_Core_Model_App->run(Array)
#22 /home/photocharms/public_html/index.php(83): Mage::run('', 'store')
#23 {main}
I have only 250 tables, the last table being 'persistent_session'
Я переустанавливал базу данных ранее и все еще получаю 250 таблиц, переустановка не идеальна, так как мы импортировали данные клиентов из другого магазина. В идеале мы хотели бы написать новые вкладки.
Любая помощь будет отличной
3 ответа
Если у вас есть рабочий файл резервной копии, пожалуйста, восстановите таблицы:
sales_order_status
sales_order_status_label
sales_order_status_state
Если у вас нет хорошего резервного копирования, вы можете переустановить только отсутствующие таблицы
Просто создайте простое расширение с 1 установочным файлом. Используйте установщик для sales_order
модуль (Mage_Sales_Model_Resource_Setup
):
https://gyazo.com/ac50353c9facfd1c1fff3f87b3e97428
Создайте установочный файл для вашего расширения: https://gyazo.com/7dde13062355e792b15b39731f5ae117
И скопируйте следующий код (это копия установщика продаж / заказа с некоторыми изменениями)
/* @var $installer Mage_Sales_Model_Entity_Setup */
$installer = $this;
$statusTable = $installer->getTable('sales/order_status');
$statusStateTable = $installer->getTable('sales/order_status_state');
$statusLabelTable = $installer->getTable('sales/order_status_label');
$installer->run("
CREATE TABLE IF NOT EXISTS `{$statusTable}` (
`status` varchar(32) NOT NULL,
`label` varchar(128) NOT NULL,
PRIMARY KEY (`status`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
");
$statuses = Mage::getConfig()->getNode('global/sales/order/statuses')->asArray();
$data = array();
foreach ($statuses as $code => $info) {
$data[] = array(
'status' => $code,
'label' => $info['label']
);
}
try {
$installer->getConnection()->insertArray($statusTable, array('status', 'label'), $data);
} catch (Exception $e) {
}
$installer->run("
CREATE TABLE IF NOT EXISTS `{$statusStateTable}` (
`status` varchar(32) NOT NULL,
`state` varchar(32) NOT NULL,
`is_default` tinyint(1) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (`status`,`state`),
CONSTRAINT `FK_SALES_ORDER_STATUS_STATE_STATUS` FOREIGN KEY (`status`)
REFERENCES `{$statusTable}` (`status`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8
");
$states = Mage::getConfig()->getNode('global/sales/order/states')->asArray();
$data = array();
foreach ($states as $code => $info) {
if (isset($info['statuses'])) {
foreach ($info['statuses'] as $status => $statusInfo) {
$data[] = array(
'status' => $status,
'state' => $code,
'is_default'=> is_array($statusInfo) && isset($statusInfo['@']['default']) ? 1 : 0
);
}
}
}
try {
$installer->getConnection()->insertArray(
$statusStateTable,
array('status', 'state', 'is_default'),
$data
);
} catch (Exception $e) {
}
$installer->run("
CREATE TABLE IF NOT EXISTS `{$statusLabelTable}` (
`status` varchar(32) NOT NULL,
`store_id` smallint(5) unsigned NOT NULL,
`label` varchar(128) NOT NULL,
PRIMARY KEY (`status`,`store_id`),
KEY `FK_SALES_ORDER_STATUS_LABEL_STORE` (`store_id`),
CONSTRAINT `FK_SALES_ORDER_STATUS_LABEL_STATUS` FOREIGN KEY (`status`)
REFERENCES `{$statusTable}` (`status`) ON DELETE CASCADE ON UPDATE CASCADE,
CONSTRAINT `FK_SALES_ORDER_STATUS_LABEL_STORE` FOREIGN KEY (`store_id`)
REFERENCES `{$installer->getTable('core/store')}` (`store_id`)ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8
");
После этого недостающие таблицы должны появиться и заполниться стандартной информацией.
Да, установочный файл должен начинаться с <?php
,
Далее вы должны убедиться, что расширение установлено правильно. Если соответствующая запись не отображается в таблице core_resource, это означает, что процесс установки по какой-то причине не удался.
Проверьте, все ли файлы на месте, особенно файлы расширений в папке app/etc/modules. Если есть таблицы, содержащие "состояние" и "метка", вы можете сократить код установщика до:
/* @var $installer Mage_Sales_Model_Entity_Setup */
$installer = $this;
$statusTable = $installer->getTable('sales/order_status');
$installer->run("
CREATE TABLE IF NOT EXISTS `{$statusTable}` (
`status` varchar(32) NOT NULL,
`label` varchar(128) NOT NULL,
PRIMARY KEY (`status`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
");
$statuses = Mage::getConfig()->getNode('global/sales/order/statuses')->asArray();
$data = array();
foreach ($statuses as $code => $info) {
$data[] = array(
'status' => $code,
'label' => $info['label']
);
}
try {
$installer->getConnection()->insertArray($statusTable, array('status', 'label'), $data);
} catch (Exception $e) {
}
Это не так сложно, особенно если учесть, что вам не нужна большая часть его функциональности.
Создайте папку app / code / local / MageWorx / Fix и подпапки: etc Helper sql
https://www.gyazo.com/cf571d50e90ce7cd5068f0f723de5103
В папке etc создайте файл: config.xml
https://www.gyazo.com/f024cbea6ae596d30f1da4715229df3b
Со следующим содержанием:
<?xml version="1.0"?>
<config>
<modules>
<MageWorx_Fix>
<version>1.0.0</version>
</MageWorx_Fix>
</modules>
<global>
<helpers>
<mageworx_fix>
<class>MageWorx_Fix_Helper</class>
</mageworx_fix>
</helpers>
<resources>
<mageworx_fix_setup>
<setup>
<module>MageWorx_Fix</module>
<class>Mage_Sales_Model_Resource_Setup</class>
</setup>
</mageworx_fix_setup>
</resources>
</global>
</config>
В папке Helper создайте файл Data.php ( https://www.gyazo.com/e5a71e283c387887da4582f04f8bf546) со следующим содержимым:
<?php
class MageWorx_Fix_Helper_Data extends Mage_Core_Helper_Abstract
{
}
В папке sql создайте подпапку mageworx_fix_setup:
https://www.gyazo.com/bd013b1fb638db1d943441eec7252baf
Внутри этого создайте файл install-1.0.0.php ( https://www.gyazo.com/cea0e9c2feedf83e3157ffcb2a85aa3f) с содержимым из исходного поста (код после фразы ") и скопируйте следующий код (это копия установщика продаж / заказа с некоторыми изменениями)"):
внутри нее создайте файл install-1.0.0.php ( https://www.gyazo.com/cea0e9c2feedf83e3157ffcb2a85aa3f) с ссылкой на оригинальное сообщение (код после фразы ") и скопируйте следующий код (это копия установщика продаж / заказа) с некоторыми изменениями)"):
В результате вы должны получить следующую структуру:
https://www.gyazo.com/b85a58a0f207ed48a774ff502e15d9b6
Последний шаг - расширение объявления. Создайте файл MageWorx_Fix.xml в каталоге app / etc / modules / со следующим содержимым:
<?xml version="1.0"?>
<config>
<modules>
<MageWorx_Fix>
<active>true</active>
<codePool>local</codePool>
</MageWorx_Fix>
</modules>
</config>
Далее откройте панель администратора, обновите кеш. Расширение будет установлено в создании таблиц. Ошибка должна уйти. Когда закончите, вы можете удалить его.