在Magento管理菜单下,客户 - >管理客户,如果字符串包含多个单词,我们无法使用他的姓名搜索客户。我在哪里可以找到执行此任务的核心代码?我们没有此部分的扩展名。
问题示例:
如果我想搜索名为John Smith的客户,搜索“john smith”将不会返回任何结果。分别搜索“john”或“smith”有效,但它会显示任何包含类似于SQL查询“LIKE %john%
或LIKE %smith%
的”john“或”smith“的名称。
答案 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;
}