首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Yii2:重音不敏感滤波器

Yii2:重音不敏感滤波器
EN

Stack Overflow用户
提问于 2018-12-12 14:24:13
回答 2查看 568关注 0票数 2

我想使用口音不敏感的搜索单词。对于不区分大小写的情况,我使用ilike

代码语言:javascript
复制
$query->andFilterWhere(['ilike', 'name', $this->name]);

但是由于口音不敏感,我不知道Yii2解决方案(否则我可以使用这个solution)。

在下一个例子中,我搜索了"camara“这个词,但是它找不到"cámara”这个词(在西班牙语中表示相机):

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-12-12 17:58:39

我使用lower_unaccent PostgreSQL函数ILIKE运算符解析它。

代码语言:javascript
复制
$query->andWhere(new Expression(
    'lower_unaccent(name) ILIKE \'%\' || lower_unaccent(\'' . $this->name . '\') || \'%\''
));
票数 0
EN

Stack Overflow用户

发布于 2020-10-20 19:26:14

我花了一段时间使用@rob006有关sql注入的评论来完成这项工作:

代码语言:javascript
复制
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 ):

代码语言:javascript
复制
$query->andFilterWhere(self::ExpressionLikeAccentInsensitive('"DB_COLUMN"', $this->DB_COLUMN));
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53745135

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档