1

大家好,我陷入了一个奇怪的位置。

我有一个带有列的表。id_acces、id_user、id_menu、has_access(布尔值)

我基本上有一个带有复选框列表和 ID 号的表单,以允许特定用户访问页面的某些部分。基本上我需要更新表格,无论是否有访问权限,如果用户没有关于选择在表格中创建新条目的页面的条目。所以我回来的数组看起来像这样

     Array
       (
        [AdminMenu] => Array
          (
            [id_user] => 1
            [id_menu] => Array
            (
                [4] => enabled
                [21] => enabled
                [22] => enabled
                [23] => enabled
                [24] => enabled
                [1] => enabled
                [5] => enabled
                [25] => enabled
                [26] => enabled
                [6] => enabled
                [7] => enabled
                [29] => enabled
                [8] => enabled
                [30] => enabled
                [31] => enabled
                [32] => enabled
                [33] => enabled
                [34] => enabled
                [35] => enabled
                [36] => enabled
                [37] => enabled
                [38] => enabled
                [39] => enabled
                [40] => enabled
                [41] => enabled
                [60] => enabled
                [2] => enabled
                [10] => enabled
                [11] => enabled
                [12] => enabled
                [13] => enabled
                [14] => enabled
                [15] => enabled
                [16] => enabled
                [17] => enabled
                [18] => enabled
                [9] => enabled
                [3] => enabled
                [19] => enabled
                [20] => enabled
            )

           )

    )

键是 id_menu,值是复选框是否被选中。

有人可以告诉我如何使用这个数组在我的表中插入或更新蛋糕 php。我目前以 $key=>$value 的形式循环遍历数组,并对表运行查询以获取键的存在。如果它存在,那么我需要运行更新查询,如果不存在,那么我需要为该特定页面或 id_menu 执行插入查询。请帮忙

    foreach($this->data['AdminMenu']['id_menu'] as $key=>$value) {
          $check = select against the table where the id_menu = $key
       if($key = $check[0]['AdminAccess']['id_menu']) {
             $this->AdminAcess->id_menu=$key;
     $this->AdminAccess->id_user=$user_id;
     $this->AdminAccess->set('has_access', 't');
     $this->AdminAccess->save();
        } else {
           $this->AdminAcess->id_menu=$key;
    $this->AdminAccess->id_user=$user_id;
    $this->AdminAccess->saveField('has_access', 'false');

         }

    }

我确定一定有比这个循环更简单的方法。另外我如何进行插入或更新。这甚至都没有进行插入或更新

4

1 回答 1

0

这是一个 hasAndBelongsToMany 关系。您应该通读 Cake Book 的这一部分,并调整您的表单代码以遵循他们的建议:

http://book.cakephp.org/2.0/en/models/saving-your-data.html#saving-habtm

于 2012-12-20T04:04:36.433 回答