在cakephp中的查询中使用LIKE条件

cra*_*rah 5 php mysql cakephp

我正在尝试找出数据库中是否已存在类似的记录,然后再继续保存记录.我用谷歌搜索,发现看起来它应该工作,但不幸的是没有.我是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核心验证规则.