Yii2:重音不敏感过滤器
Yii2: accent insensitive filter
我想使用 不区分重音 来搜索单词。对于不区分大小写,我使用 ilike:
$query->andFilterWhere(['ilike', 'name', $this->name]);
但是对于重音不敏感,我不知道 Yii2 解决方案(否则我可以使用这个 PHP solution)。
在下一个示例中,我搜索了词 "camara",但没有找到词 "cámara"(在西班牙语中表示相机):
我使用 lower_unaccent PostgreSQL 函数 和 ILIKE PostgreSQL 运算符:
解决了这个问题
$query->andWhere(new Expression(
'lower_unaccent(name) ILIKE \'%\' || lower_unaccent(\'' . $this->name . '\') || \'%\''
));
我花了一些时间来使用 @rob006 关于 sql 注入的评论:
private static function ExpressionLikeAccentInsensitive($col, $field){
$bind = md5($col);
return [
'ilike',
new Expression("lower(unaccent({$col}))"),
new Expression("'%' || lower(unaccent(:q{$bind})) || '%'", [
":q{$bind}"=>$field
]),
];
}
然后你这样称呼它(使用 Postgres ILKE 的例子):
$query->andFilterWhere(self::ExpressionLikeAccentInsensitive('"DB_COLUMN"', $this->DB_COLUMN));
我想使用 不区分重音 来搜索单词。对于不区分大小写,我使用 ilike:
$query->andFilterWhere(['ilike', 'name', $this->name]);
但是对于重音不敏感,我不知道 Yii2 解决方案(否则我可以使用这个 PHP solution)。
在下一个示例中,我搜索了词 "camara",但没有找到词 "cámara"(在西班牙语中表示相机):
我使用 lower_unaccent PostgreSQL 函数 和 ILIKE PostgreSQL 运算符:
解决了这个问题$query->andWhere(new Expression(
'lower_unaccent(name) ILIKE \'%\' || lower_unaccent(\'' . $this->name . '\') || \'%\''
));
我花了一些时间来使用 @rob006 关于 sql 注入的评论:
private static function ExpressionLikeAccentInsensitive($col, $field){
$bind = md5($col);
return [
'ilike',
new Expression("lower(unaccent({$col}))"),
new Expression("'%' || lower(unaccent(:q{$bind})) || '%'", [
":q{$bind}"=>$field
]),
];
}
然后你这样称呼它(使用 Postgres ILKE 的例子):
$query->andFilterWhere(self::ExpressionLikeAccentInsensitive('"DB_COLUMN"', $this->DB_COLUMN));