2012-10-12 25 views
0

我有三个型号:CakePHP的 - 储存的外键

  1. 用户
  2. 评论

一个用户可以有数倍的音符(通过音符我的意思是像Facebook状态)和一张纸条可以有多个评论。

在评论表中,我想存储实际上是外键的user_id和note_id。

评论控制器:

public function userscomment() 
{ 
    if (!empty($this->data)) 
    { 
     $commentdata = $this->data; 
     $commentdata['Comment']['user_id'] = $this->Auth->user('id'); 
     $this->Comment->save($commentdata); 
    } 

现在,作为用户id容易识别,它存储在数据库中,但我怎么确定的评论是这张纸币?

如何存储评论的注释ID?

+0

你会通常与笔记ID您的网页上隐藏的表单输入:'' –

+0

请问你能更清楚些吗,我没搞明白 –

回答

0

在你看来,你有你的表单输入评论,您可以指定发送照会ID到控制器这样的形式操作:

应用程序/浏览/评论/ userscomment.ctp

echo $this->Form->create('Comment', array(
    'url' => array('385') // 385 is the note_id 
)); 
echo $this->Form->textarea('comment'); 

echo $this->Form->end('Submit Comment'); 

应用/控制器/ CustomersController.php

public function userscomment($note_id) { 

    if (!empty($this->data)) { 

     $commentdata = $this->data; 
     $commentdata['Comment']['user_id'] = $this->Auth->user('id'); 
     $commentdata['Comment']['note_id'] = $note_id; 
     $this->Comment->save($commentdata); 

    } 
} 
+0

这是什么问题呢。在这里你已经手动输入了ID,但是我不知道如何自动调用ID。就像每个音符都有一个唯一的ID一样,所以如何通过Auth组件调用用户ID。 –

+0

好的,在某个地方你必须知道视图中的音符ID,不是吗?否则,你如何显示该笔记或已经存在的评论?你可以发布你的视图HTML,所以我可以看看? – BadHorsie

+0

检查下面的视图和控制器。 –

0

控制器:

公共职能的NotesView() {

$allnotes = $this->User->Note->find('all', array('order'=>'Note.created DESC')); 


    if (!empty($this->params['requested'])) 
     {    
     return $allnotes;   
     } 
    } 

VIEW:

<?php 
echo $this->Html->css('notes'); 
echo $this->Html->script(array('jquery','jquery.elastic','notes')); 
?> 
<div class="notescontainer"> 
<div class="share">Share:</div> 
<div class="notes">Notes</div> 
<div class="loading"></div> 
<div class="img_top"></div> 
<div class="text_status"> 

<?php 
echo $this->form->create('Note', array('action' => 'notes', 'onSubmit' => 'return loadingicon();')); 
echo $this->form->input('notes',array('class'=>'notesbar','label'=>'','placeholder'=>'Write down you notes ...')); 
?> 
</div> 
<div class="button_outside_border" id="share"> 
<div class="button_inside_border"> 

<?php 
echo $this->form->submit('Share',array('class' => 'sharebutton')); 
echo $this->form->end(); 
?> 
</div> 
</div> 
<div class="clear"></div> 
</div> 

<?php 

$allnotes = $this->requestAction(array('controller'=>'Users', 'action'=>'notesview')); 
foreach($allnotes as $viewnotes): 
{ 
    echo "<div class='load_status'>"; 

    echo "<img class='status_img' src="; echo $viewnotes['User']['image']; echo ">"; 

    echo "<div class='status_text'>" ?> 

    <a href="users/profileview/<?php echo $viewnotes['User']['id']?>" class='blue'> 
    <?php 
    echo $viewnotes['User']['name']; 
    echo "</a>"; 

    echo "<p class='text'>"; 
    echo $viewnotes['Note']['notes']; 
    echo "</p>"; 


    echo " 
    <a href='#' class='light_blue'>Like</a> &middot; 
    <a href='#' class='light_blue'>Comment</a> &middot "; 
    echo "<u class='date'>"; echo $viewnotes['Note']['created']; echo"</u>"; 

    echo $this->element('comments'); 

    echo "</div>"; 


    echo "<div class='clear'></div>"; 
    echo "</div>"; 


} 
endforeach; 
?>