0

在我的 Yii 应用程序中,我有这个关系(产品有很多属性),产品表主键是自动递增的,属性表有外键 product_id 到相关产品。当我在 yii 中使用事务来保存父级(产品)和子级(属性)时,出现错误(product_id 不能为空),这是因为 ($product->id) 在事务中保存后返回 NULL。这是我的代码:

        $transaction = Yii::app()->db->beginTransaction();
    try {
        $product = new Product;
        $product->name = 'name_product';

        if ($product->save()) {
            $product_attribut = new ProductAtt;
            $product_attribut->product_id = $product->id;
            $product_attribut->name = 'att_name';
            $product_attribut->value = 22;
            if (!$product_attribut->save()) {
                throw new Exception('fail');
            }
        } else {
            throw new Exception('fail');
        }

        $transaction->commit();
        echo 'success';
    } catch (Exception $e) {
        $transaction->rollback();
        echo $e->getMessage();
    }

请在交易中保存这种关系的任何想法.. 谢谢。

4

1 回答 1

1

以防万一其他人遇到这个问题,我找到了迄今为​​止在我读过的所有类似问题中没有提到的解决方案:

确保您已经为您的数据库分配了一个主键。即使您有一个自动增量字段,这也不一定意味着您已经定义了一个主键。Yii 读取数据库模式并使用此信息来确定存在哪些主键,以及随后如何在插入后更新记录中的主键。因此,即使您的ActiveRecord 定义已经定义了主键,这也是不够的。

Yii::app()->db->getLastInsertID() 实际上适用于这种情况,但是我怀疑这是否适用于多会话环境。如果您还没有定义主键显然是更好的解决方案。

希望这对其他人有帮助!

于 2016-12-01T21:59:18.077 回答