1

在我的数据库中执行搜索时遇到问题。我的表有以下记录:

id : 5
Name : Nicolás
created : 2015-12-15 13:08:22
modified : 2015-12-15 13:08:22

我的职责之一是根据用户输入的内容进行搜索:

$replaceConditionsInBD = "CONVERT( CAST( UPPER(TRIM(REPLACE(REPLACE(REPLACE(InscripcionesAtributo.valor, ',',''), '.',''), '-',''))) AS BINARY) USING utf8) LIKE";
$condition = '%'.$valor.'%';
$participantes = $this->Participante->Inscripcion->InscripcionesAtributo->find('all', array(
    'conditions' => array(
        $replaceConditionsInBD => $condition,
    ),
    'group'=> array('InscripcionesAtributo.inscripcion_id'),
    'fields'=> array('Inscripcion.id'),
    'contain'=> array('Inscripcion.evento_id = '.$this->eventoID)));        

如果我使用重音执行搜索,例如 name Nicolás,它不会返回任何结果。但是,如果我搜索Nicolas(不带重音),就会找到记录。

我需要的是能够执行不区分重音的搜索。这应该适用于其他外来字符,例如字母Ñ

4

1 回答 1

3

有几种方法可以做到这一点,但也许最简单的方法是将表格的排序规则更改为utf8_general_ci

ALTER TABLE inscripciones_atributos COLLATE = utf8_general_ci;

这将允许您执行不区分大小写和不区分重音的搜索,以及其他字符等价,如下所示:

确保记录采用 UTF8 编码。

于 2015-12-15T23:46:01.253 回答