Ahoj,
potreboval bych poradit jak upravit system/library/request.php tak, aby byl vysledek hledani s diakritikou stejny jako bez ni... napriklad na vyraz "potrubi" ted nenajde nic, avsak s diakritikou "potrubí" vyhleda vsechny trubky v mem eshopu ... v1.5.1
bye clad
Ahoj,
řešení vyžaduje menší úpravu systému OpenCart - potřebuješ dostat do databáze dvě verze textů (tj. přidáš ke každému vyhledávanému textu další sloupec tabulky), ve kterých systém pak vyhledává - jedna verze je ta oficiální, s diakritikou, druhá pak bez diakritiky kvůli vyhledávání. Následně stačí upravit vyhledávací SQL dotazy tak, aby braly v potaz i texty bez diakritiky.
Bohužel MySQL databáze neumí pracovat při porovnávání řetězců s diakritikou, je třeba to obcházet.
řešení vyžaduje menší úpravu systému OpenCart - potřebuješ dostat do databáze dvě verze textů (tj. přidáš ke každému vyhledávanému textu další sloupec tabulky), ve kterých systém pak vyhledává - jedna verze je ta oficiální, s diakritikou, druhá pak bez diakritiky kvůli vyhledávání. Následně stačí upravit vyhledávací SQL dotazy tak, aby braly v potaz i texty bez diakritiky.
Bohužel MySQL databáze neumí pracovat při porovnávání řetězců s diakritikou, je třeba to obcházet.
Predem musim rict, ze moc php a mysql nerozumim, ale tohle mi prijde jako hodne nesystemovy workaround. Nejenom, ze je to pracny a musel bych znat vsechna slova, ktera budou klienti vyhledavat, ale neresil by se tim stav, kdy klient treba zapomnel napsat jen jeden hacek a ostani diakritiku by tam dal.
Dalo by se implementovat toto reseni http://php.vrana.cz/vyhledani-textu-bez-diakritiky.php ?
Dalo by se implementovat toto reseni http://php.vrana.cz/vyhledani-textu-bez-diakritiky.php ?
Vlastně dalo - to poslední řešení mi přijde jako nejideálnější. V tom případě by stačil upravit SQL dotaz.
V tom pripade bych rad poukazal na svoji nezkusenost a poprosil nekoho z vas, znaleho a ochotneho, pomoci upravit SQL dotaz v request.php, pripadne i jinde, kde je to potreba. Ucim se, ale tady opravdu nevim kde zacit... presneji nevim jake promenne pouzit... diky, myslim ze to bude uzitecne i pro ostatni.
Přepsal jsem část souboru /catalog/model/catalog/product.php, konkrétně metodu getProducts() (řádek 60), která má na starosti i vyhledávání produktů v databázi. Původní metodu stačí nahradit touto:
Přiznám se, že jsem výsledek příliš netestoval, ale úspěšně mi vracela výsledky jak na řetězce s diakritikou, částečně s diakritikou, tak i bez ní.
Code: Select all
public function getProducts($data = array()) {
if ($this->customer->isLogged()) {
$customer_group_id = $this->customer->getCustomerGroupId();
} else {
$customer_group_id = $this->config->get('config_customer_group_id');
}
$cache = md5(http_build_query($data));
$product_data = $this->cache->get('product.' . $cache . '.' . $customer_group_id);
if (!$product_data) {
$sql = "SELECT p.product_id, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.status = '1' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'";
if (isset($data['filter_name']) && $data['filter_name']) {
if (isset($data['filter_description']) && $data['filter_description']) {
$sql .= " AND (LCASE(pd.name) LIKE '%" . $this->db->escape(mb_strtolower($data['filter_name'], 'UTF-8')) . "%' COLLATE utf8_general_ci OR p.product_id IN (SELECT pt.product_id FROM " . DB_PREFIX . "product_tag pt WHERE pt.language_id = '" . (int)$this->config->get('config_language_id') . "' AND LCASE(pt.tag) LIKE '%" . $this->db->escape(mb_strtolower($data['filter_name'], 'UTF-8')) . "%' COLLATE utf8_general_ci) OR LCASE(pd.description) LIKE '%" . $this->db->escape(mb_strtolower($data['filter_name'], 'UTF-8')) . "%' COLLATE utf8_general_ci)";
} else {
$sql .= " AND (LCASE(pd.name) LIKE '%" . $this->db->escape(mb_strtolower($data['filter_name'], 'UTF-8')) . "%' COLLATE utf8_general_ci OR p.product_id IN (SELECT pt.product_id FROM " . DB_PREFIX . "product_tag pt WHERE pt.language_id = '" . (int)$this->config->get('config_language_id') . "' AND LCASE(pt.tag) LIKE '%" . $this->db->escape(mb_strtolower($data['filter_name'], 'UTF-8')) . "%' COLLATE utf8_general_ci))";
}
}
if (isset($data['filter_tag']) && $data['filter_tag']) {
$sql .= " AND p.product_id IN (SELECT pt.product_id FROM " . DB_PREFIX . "product_tag pt WHERE pt.language_id = '" . (int)$this->config->get('config_language_id') . "' AND LCASE(pt.tag) LIKE '%" . $this->db->escape(mb_strtolower($data['filter_tag'], 'UTF-8')) . "%' COLLATE utf8_general_ci)";
}
if (isset($data['filter_category_id']) && $data['filter_category_id']) {
if (isset($data['filter_sub_category']) && $data['filter_sub_category']) {
$implode_data = array();
$this->load->model('catalog/category');
$categories = $this->model_catalog_category->getCategoriesByParentId($data['filter_category_id']);
foreach ($categories as $category_id) {
$implode_data[] = "p2c.category_id = '" . (int)$category_id . "'";
}
$sql .= " AND p.product_id IN (SELECT p2c.product_id FROM " . DB_PREFIX . "product_to_category p2c WHERE " . implode(' OR ', $implode_data) . ")";
} else {
$sql .= " AND p.product_id IN (SELECT p2c.product_id FROM " . DB_PREFIX . "product_to_category p2c WHERE p2c.category_id = '" . (int)$data['filter_category_id'] . "')";
}
}
if (isset($data['filter_manufacturer_id'])) {
$sql .= " AND p.manufacturer_id = '" . (int)$data['filter_manufacturer_id'] . "'";
}
$sql .= " GROUP BY p.product_id";
$sort_data = array(
'pd.name',
'p.model',
'p.quantity',
'p.price',
'rating',
'p.sort_order',
'p.date_added'
);
if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
if ($data['sort'] == 'pd.name' || $data['sort'] == 'p.model') {
$sql .= " ORDER BY LCASE(" . $data['sort'] . ")";
} else {
$sql .= " ORDER BY " . $data['sort'];
}
} else {
$sql .= " ORDER BY p.sort_order";
}
if (isset($data['order']) && ($data['order'] == 'DESC')) {
$sql .= " DESC";
} else {
$sql .= " ASC";
}
if (isset($data['start']) || isset($data['limit'])) {
if ($data['start'] < 0) {
$data['start'] = 0;
}
if ($data['limit'] < 1) {
$data['limit'] = 20;
}
$sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
}
$product_data = array();
$query = $this->db->query($sql);
foreach ($query->rows as $result) {
$product_data[$result['product_id']] = $this->getProduct($result['product_id']);
}
$this->cache->set('product.' . $cache . '.' . $customer_group_id, $product_data);
}
return $product_data;
}
Who is online
Users browsing this forum: No registered users and 5 guests