多行中的cakephp外键不起作用

Posted

技术标签:

【中文标题】多行中的cakephp外键不起作用【英文标题】:cakephp foreign key in multiple rows not working 【发布时间】:2014-05-09 11:14:39 【问题描述】:

我有 2 张桌子:

门票

`CREATE TABLE IF NOT EXISTS `tickets` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `nom_model` varchar(32) NOT NULL,
  `is_active` tinyint(1) NOT NULL,
  `date_modif` date NOT NULL,
  PRIMARY KEY (`id`));`

详情

  `CREATE TABLE IF NOT EXISTS `details` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `ticket_id` int(11) NOT NULL,
  `nom` varchar(32) NOT NULL,
  `text` varchar(32) NOT NULL,
  `taille` enum('8','9','10','11','12','13','14','15','16','17','18','19','20') NOT NULL,
  `police` enum('Impact','courier new','times new roman','comic sans ms') NOT NULL,
  `bold` int(2) NOT NULL,
  `italic` int(2) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `ticket_id` (`ticket_id`));`

门票有 11 个 zone (msg_acc, nom_buro,heure, date ....) 哪些是表详细信息中字段 nom 的属性 并且在一个区域中有(文本、警察、粗体、斜体)

因此必须在表中保存 11 行(详细信息)

我想创建表单(包含表票证中的 nom 模型并在表详细信息中保存 11 行,表详细信息中的外键票证 ID 是新票证创建(nom_model)):

我创建表单保存 11 行市场很好,但前键不起作用 nom_model 不保存在表中(票证)和 11 行保存票证 ID 等于 0

模型 Ticket.php 中的代码

 <?php
class Ticket extends AppModel

   var $name = 'Ticket';
   public $displayField='id';
   public $hasMany = array(
   'Detail'
   );

?>

模型Detail.php中的代码

    <?php
class Detail extends AppModel   
   var $name = 'Detail';
   public $belongsTo = array(
   'Ticket'
   );

?>

控制器 detailsController.php 中的代码

    $this->set('title_for_layout', __('Add Details'));
        $tickets= $this->Detail->Ticket->find('list');
        if (!empty($this->request->data)) 
        if($this->Detail->saveAll($this->request->data['Detail']))
          $this->Session->setFlash(__('The Model has been saved'));
            $this->redirect(array('action' => 'index'));
         else 
            $this->Session->setFlash(__('The Model could not be saved. Please, try again.'));
              
          $this->redirect(array('action' => 'index'));

             
                $this->set('tickets', $tickets);

视图 add.ctp 中的第一个代码

<?php echo $this->form->create('Detail');?>
   <fieldset>
      <legend>Add New Detail</legend>
   <?php
   echo $this->form->input('Ticket.$i.nom_model');//not working
   for($i=0;$i<$count;$i++)
      echo $this->form->input("Detail.$i.name");
      echo $this->form->input("Detail.$i.text");
      echo $this->form->input("Detail.$i.taille");
      echo $this->form->input("Detail.$i.police");
      echo $this->form->input("Detail.$i.bold");
      echo $this->form->input("Detail.$i.italic");
       $this->form->hidden('ticket_id'); ?> </fieldset>
      <?php echo $this->form->end('Submit');?> 

【问题讨论】:

我找不到解决办法 注意:在您看来,您忘记了生成隐藏字段的回显。 【参考方案1】:

您通过saveAll 保存您的请求数据没有您的关联票证

Ticked的关联数据位于$this-&gt;request-&gt;data['Ticket'],将被忽略:

//(Line 4 of your posted controller)
$this->Detail->saveAll($this->request->data['Detail'])

更新:

您的$this-&gt;request-&gt;data 应具有以下结构:

Array
(
   [Ticket] => Array
                 (
                       [id] => 1
                       ...
                 )
   [Detail] => Array
                      (
                       [0] => Array
                             (                                 
                               [ticket_id] => 1
                               ...
                             )

                       [1] => Array
                             (                                  
                               [ticket_id] => 1
                               ...
                             )
                       ..........
                     )
)

调整您的视图,生成该数据字段,然后您可以尝试通过$this-&gt;Detail-&gt;saveAll($this-&gt;request-&gt;data)保存发布的数据

更新

您的基本视图应如下所示:

   <fieldset>
      <legend>Add New Detail</legend>
   <?php

   echo $this->form->input("Ticket.nom_model");
   echo $this->form->hidden("Ticket.id", array('value' => '1'));
   for($i=0;$i < $count;$i++)
      echo $this->form->input("Detail.$i.name");
      echo $this->form->input("Detail.$i.text");
      echo $this->form->input("Detail.$i.taille");
      echo $this->form->input("Detail.$i.police");
      echo $this->form->input("Detail.$i.bold");
      echo $this->form->input("Detail.$i.italic");
      echo $this->form->hidden("Detail.$i.ticket_id", array('value' => '1')); ?> 
   <?php echo $this->form->end('Submit');?> 

   </fieldset>

这是一个示例视图,通过Ticked.id = 1Detail 引用到Ticket

更新:

您应该在Models/Detail.php 中定义从DetailTicket 的外键:

public $belongsTo = array(
    'Ticket' => array(
        'className' => 'Ticket',
        'foreignKey' => 'ticket_id'
        )
   );

【讨论】:

我更改了 $this->Detail->saveAll($this->request->data['Detail']) to $this->Detail->saveAll($this->request->data['Ticket']) 我已经发布了数据字段,您的表单应该会生成。 另外我发布了一个示例视图 这是工作票 ID,值为 1,但我希望票证为最后一个值(exp:在表票中,我有 5 张票,票证 ID 必须为 5)

以上是关于多行中的cakephp外键不起作用的主要内容,如果未能解决你的问题,请参考以下文章

实体框架核心外键不起作用

cakephp hasone 和所属加入不起作用

为啥 PyQt 中的 keyPress 事件对 Enter 键不起作用?

在 IE8 中输入表单中的键不起作用

vscode中的vue文件中emmet进行tab键不起作用

vscode中的vue文件中emmet进行tab键不起作用