Post by clad » Mon Sep 19, 2011 2:00 am

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

Newbie

Posts

Joined
Mon Sep 19, 2011 1:55 am

Post by lord_thomas » Mon Sep 19, 2011 1:57 pm

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.

Newbie

Posts

Joined
Thu Sep 15, 2011 4:39 am

Post by clad » Mon Sep 19, 2011 2:24 pm

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 ?

Newbie

Posts

Joined
Mon Sep 19, 2011 1:55 am

Post by lord_thomas » Mon Sep 19, 2011 2:32 pm

Vlastně dalo - to poslední řešení mi přijde jako nejideálnější. V tom případě by stačil upravit SQL dotaz.

Newbie

Posts

Joined
Thu Sep 15, 2011 4:39 am

Post by clad » Tue Sep 20, 2011 1:58 am

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.

Newbie

Posts

Joined
Mon Sep 19, 2011 1:55 am

Post by lord_thomas » Tue Sep 20, 2011 4:28 am

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:

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;
	}
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í.

Newbie

Posts

Joined
Thu Sep 15, 2011 4:39 am
Who is online

Users browsing this forum: No registered users and 6 guests