Magento:如何修复客户名称搜索

时间:2012-07-27 16:40:21

标签: magento

在Magento管理菜单下,客户 - >管理客户,如果字符串包含多个单词,我们无法使用他的姓名搜索客户。我在哪里可以找到执行此任务的核心代码?我们没有此部分的扩展名。

问题示例:

如果我想搜索名为John Smith的客户,搜索“john smith”将不会返回任何结果。分别搜索“john”或“smith”有效,但它会显示任何包含类似于SQL查询“LIKE %john%LIKE %smith%的”john“或”smith“的名称。

1 个答案:

答案 0 :(得分:1)

看起来你正在使用Magento 1.6版

这是一个错误,已在1.7中修复

以下是需要修改的代码:app / code / core / Mage / Customer / Model / Resource / Customer / Collection.php

我发布了从1.7版本开始的代码:

Mage_Customer_Model_Resource_Customer_Collection    

    public function addNameToSelect()
    {
        $fields = array();
        $customerAccount = Mage::getConfig()->getFieldset('customer_account');
        foreach ($customerAccount as $code => $node) {
            if ($node->is('name')) {
                $fields[$code] = $code;
            }
        }

        $adapter = $this->getConnection();
        $concatenate = array();
        if (isset($fields['prefix'])) {
            $concatenate[] = $adapter->getCheckSql(
                '{{prefix}} IS NOT NULL AND {{prefix}} != \'\'',
                $adapter->getConcatSql(array('LTRIM(RTRIM({{prefix}}))', '\' \'')),
                '\'\'');
        }
        $concatenate[] = 'LTRIM(RTRIM({{firstname}}))';
        $concatenate[] = '\' \'';
        if (isset($fields['middlename'])) {
            $concatenate[] = $adapter->getCheckSql(
                '{{middlename}} IS NOT NULL AND {{middlename}} != \'\'',
                $adapter->getConcatSql(array('LTRIM(RTRIM({{middlename}}))', '\' \'')),
                '\'\'');
        }
        $concatenate[] = 'LTRIM(RTRIM({{lastname}}))';
        if (isset($fields['suffix'])) {
            $concatenate[] = $adapter
                    ->getCheckSql('{{suffix}} IS NOT NULL AND {{suffix}} != \'\'',
                $adapter->getConcatSql(array('\' \'', 'LTRIM(RTRIM({{suffix}}))')),
                '\'\'');
        }

        $nameExpr = $adapter->getConcatSql($concatenate);

        $this->addExpressionAttributeToSelect('name', $nameExpr, $fields);

        return $this;
    }