doutizhou5312 2012-02-28 16:23
浏览 12
已采纳

设置另一个字段的ID值

Can I set the model record ID for another field value? (without update it)

In the other way, mix this code to one or two line:

$this->Model->create($data);
$this->Model->save();

$this->Model->create($data); // create again
$this->Model->set('link', $this->Model->id); // get record id
$this->Model->save(); // update

Thanks.

  • 写回答

1条回答 默认 最新

  • dongyu1918 2012-02-29 03:25
    关注

    Yes, but you need to make the proper calls to the proper model methods. You will also need to make certain you are storing the information correctly in the array you are passing to save. So let's say you are adding a record to the places table. Let's say your schema looks like this:

    CREATE TABLE 'places' (
    `id` CHAR(36) NOT NULL,
    `reference_id` CHAR(36) NULL,
    `name` VARCHAR(50) NOT NULL,
    PRIMARY KEY (`id`)
    );
    

    Then you have the following:

    $data['Place']['name'] = 'New York';
    
    // create the first record to get the PK ID that will 
    // be used in the reference_id of the next record
    
    $this->Place->create();
    $this->Place->save($data);
    
    // set the reference ID to the ID of the previously saved record
    $data['Place']['reference_id'] = $this->Place->id;
    
    // create the next record recording the previous ID as
    // the reference_id
    $this->Place->create();
    $this->Place->save($data);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog