php - 添加自定义 magento 选项失败 : Integrity constraint violation

标签 php mysql magento foreign-keys magento-1.9

我正在尝试从代码创建自定义选项,但是当我尝试为“值”数组赋值时,出现此错误(参见图片)。

因此,如果我创建一个没有字段的选项('values' 空数组)一切正常,但如果我放置一个包含一些元素的数组,它就会出错。

我不明白为什么函数“addOption ()”不能保证 key 的完整性,或者我做错了什么。

下面也是这段代码:

// ... get function params etc ...

// conf
$product_id = 1686;
$store = 0;

// init
$product = Mage::getModel('catalog/product')->setStoreId($store)->load($product_id);
$options = Mage::getModel('catalog/product_option')->getProductOptionCollection($product);

// ... options clearing ...

// set option

$option = array(
            'title' => 'bundle',
            'type' => 'radio',
            'is_required' => 1,
            'sort_order' => 0,
            'values' => array(
                array(
                    'title' => 'Standard',
                    'price' => 10.11, 
                    'price_type' => 'fixed',
                    'sku' => 'ex_standard',
                    'sort_order' => 0,
                ),
                array(
                    'title' => 'Premium',
                    'price' => 20.50,
                    'price_type' => 'fixed',
                    'sku' => 'ex_premium',
                    'sort_order' => 0,
                ),
                array(
                    'title' => 'Deluxe',
                    'price' => 85.00,
                    'price_type' => 'fixed',
                    'sku' => 'ex_deluxe',
                    'sort_order' => 0,
                )
            )
        );

// apply changes

$product->setCanSaveCustomOptions(true);
$product->getOptionInstance()->addOption($option);
$product->setHasOptions(true);
$product->save();

注意事项: 基于 Magento 1.9,对于自定义选项,我们使用 MageWorx 实现。

Error

最佳答案

我发现了一种克服错误的方法:简单地禁用外键控制。

主类函数

$write = Mage::getSingleton("core/resource")->getConnection("core_write");

$this->setKeyCheck($write,0); // disable foreign keys

/* ... Generate options ... */

$this->setKeyCheck($write,1); // enable foreign keys

解析函数的定义

private function setKeyCheck($write,$status){
      $write->query("SET FOREIGN_KEY_CHECKS={$status}");
    }

关于php - 添加自定义 magento 选项失败 : Integrity constraint violation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52334408/

相关文章:

php - mysqli_fetch_array在已部署的服务器上不起作用

php - 数据库设计 : implementing several types of the same entity

php - 当我通过电子邮件地址选择时,为什么会出现 MySQL 语法错误 (1604)?

PHP - 创建表失败

mySQL 5.5.43 语法错误

php - 如果 MYSQL 不同

magento - 获取集合 : Magento 时属性名称无效

MySQL 自连接查询优化

html - Magento 站点在 chrome 移动浏览器上比在 chrome 桌面浏览器上更宽-由于右浮动 div?-需要天才

javascript - zoomplus magento - 无法滚动