我正在尝试找出数据库中是否已存在类似的记录,然后再继续保存记录.我用谷歌搜索,发现看起来它应该工作,但不幸的是没有.我是cakephp的新手,可以找出正确的查询.
$this->Tape->recursive = -1;
$tapeexists = $this->Tape->find('all', array('condition'=>array('Tape.name LIKE'=>'blondie%')));
$this->set('output', $tapeexists);
Run Code Online (Sandbox Code Playgroud)
如果我在视图中print_r()结果,我可以看到它只是去了并获得该表中的所有结果,其中没有任何名称甚至像'blondie'一样远!
Thi*_*zzi 14
我觉得你conditions在做你的发现时只是拼错了:
$tapeexists = $this->Tape->find('all', array('conditions'=>array('Tape.name LIKE'=>'blondie%')));
Run Code Online (Sandbox Code Playgroud)
这应该会给你预期的结果.
为了您不允许重复的特定目标,我建议在Tape模型上创建验证规则.有一个特定的内置规则旨在避免重复,所以你可能最好使用它.在此处查看有关数据验证的更多信息- 查看isUnique核心验证规则.
| 归档时间: |
|
| 查看次数: |
15957 次 |
| 最近记录: |