CakePHP有许多通过(连接模型)不保存


CakePHP hasMany through (the join model) not saving

我有一个hasMany通过(连接模型),这不是节省,但在阅读时,它自然地工作。

我将尽量提供尽可能多的细节,所以请原谅我。请注意,我正在尝试保存与现有产品数量配对的新用户,并且我不想在此保存中添加新产品。

Database Tables: users, products, subscribed_users

连接表的表结构:id, user_id, product_id, quantity, created, modified

User.php

public $hasMany = array(
   'SubscribedUser'
);

Product.php

public $hasMany = array(
   'SubscribedUser'
);

SubscribedUser.php

class SubscribedUser extends AppModel {
   public $belongsTo = array(
       'User', 'Product'
   );
}

我试图从UsersController.php中保存的数据数组

Array (
    [User] => Array (
        [username] => asdf
    )
    [SubscribedUser] => Array (
        [0] => Array (
            [product_id] => 50f1ef25-6884-44cf-80e4-bd346f01a4c2
            [count] => 12
        )
        [1] => Array (
            [product_id] => 50f1f1d6-89b4-4ade-961f-c1a06f01a4c2
            [count] => 12
        )
    )
)

使用$ this ->用户-> SubscribedUser ->节约装置(元数据);我正确地保存了User,但是我的subscribed_users表只有一行(从上面的数据中可以看到,应该有两行),并且它包含丢失的数据。没有product_id,计数数为0。

我不知道我在这里错过了什么。想法吗?

除非是拼写错误,否则文件名Users.php是最明显的错误。

问题是我使用$this->User->SubscribedUser->saveAll()而不是$this->User->saveAll()

我的问题现在解决了这个分辨率