多行中的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->request->data['Ticket']
,将被忽略:
//(Line 4 of your posted controller)
$this->Detail->saveAll($this->request->data['Detail'])
更新:
您的$this->request->data
应具有以下结构:
Array
(
[Ticket] => Array
(
[id] => 1
...
)
[Detail] => Array
(
[0] => Array
(
[ticket_id] => 1
...
)
[1] => Array
(
[ticket_id] => 1
...
)
..........
)
)
调整您的视图,生成该数据字段,然后您可以尝试通过$this->Detail->saveAll($this->request->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 = 1
将Detail
引用到Ticket
更新:
您应该在Models/Detail.php
中定义从Detail
到Ticket
的外键:
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外键不起作用的主要内容,如果未能解决你的问题,请参考以下文章