【问题标题】:Yii2: accent insensitive filterYii2:重音不敏感过滤器
【发布时间】:2019-05-13 16:23:16
【问题描述】:

我想使用不区分重音来搜索字词。对于不区分大小写,我使用 ilike

$query->andFilterWhere(['ilike', 'name', $this->name]);

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

在下一个示例中,我搜索了“camara”这个词,但没有找到“cámara”这个词(在西班牙语中是相机的意思):

【问题讨论】:

  • 嗯.. 在你的 sql 查询中改变运行时的排序规则,看到这个答案 stackoverflow.com/questions/8647080/… ,你只需要告诉 MySQL 使用不同的排序规则。
  • 感谢@MuhammadOmerAslam,但我不想接触 PostgreSQL 数据库。

标签: postgresql yii2 accent-insensitive


【解决方案1】:

我使用 lower_unaccent PostgreSQL 函数ILIKE PostgreSQL 运算符解决了这个问题:

$query->andWhere(new Expression(
    'lower_unaccent(name) ILIKE \'%\' || lower_unaccent(\'' . $this->name . '\') || \'%\''
));

【讨论】:

  • 您的查询中似乎存在 SQLi 漏洞。您应该在 PHP 级别使用准备好的语句和参数而不是串联。
【解决方案2】:

用@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));

【讨论】:

    猜你喜欢
    • 2021-03-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-09-28
    • 2013-01-15
    • 2013-01-21
    • 2017-08-15
    • 2016-05-30
    相关资源
    最近更新 更多