function translit($str) {
$rus = array('А', 'Б', 'В', 'Г', 'Д', 'Е', 'Ё', 'Ж', 'З', 'И', 'Й', 'К', 'Л', 'М', 'Н', 'О', 'П', 'Р', 'С', 'Т', 'У', 'Ф', 'Х', 'Ц', 'Ч', 'Ш', 'Щ', 'Ъ', 'Ы', 'Ь', 'Э', 'Ю', 'Я', 'а', 'б', 'в', 'г', 'д', 'е', 'ё', 'ж', 'з', 'и', 'й', 'к', 'л', 'м', 'н', 'о', 'п', 'р', 'с', 'т', 'у', 'ф', 'х', 'ц', 'ч', 'ш', 'щ', 'ъ', 'ы', 'ь', 'э', 'ю', 'я');
$lat = array('A', 'B', 'V', 'G', 'D', 'E', 'E', 'Gh', 'Z', 'I', 'Y', 'K', 'L', 'M', 'N', 'O', 'P', 'R', 'S', 'T', 'U', 'F', 'H', 'C', 'Ch', 'Sh', 'Sch', 'Y', 'Y', 'Y', 'E', 'Yu', 'Ya', 'a', 'b', 'v', 'g', 'd', 'e', 'e', 'gh', 'z', 'i', 'y', 'k', 'l', 'm', 'n', 'o', 'p', 'r', 's', 't', 'u', 'f', 'h', 'c', 'ch', 'sh', 'sch', 'y', 'y', 'y', 'e', 'yu', 'ya');
return str_replace($rus, $lat, $str);
}
}
function getUniqCategorySlug($new_slug){
$db=JFactory::getDBO();
$db->setQuery("SELECT COUNT(*) FROM #__virtuemart_categories_ru_ru WHERE slug='$new_slug'");
$cnt=$db->loadResult();
if ($db->getErrorNum()) {
echo $db->stderr(true);
die("1117");
}
if(empty($cnt)){
return true;
}else{
return false;
}
}
$db = JFactory::getDBO();
$is_categories = false;
if ($is_categories) {
$db->setQuery("SELECT * FROM #__virtuemart_categories_ru_ru ");
$rows = $db->loadObjectList();
if ($db->getErrorNum()) {
echo $db->stderr(true);
die("111");
}
foreach ($rows AS $r) {
$new_slug = translit($r->slug);
$idx=1;
$new_slug_base=$new_slug;
while(!getUniqCategorySlug($new_slug)){
$new_slug=$new_slug_base.$idx;
$idx++;
}
$db->setQuery("UPDATE #__virtuemart_categories_ru_ru SET slug='$new_slug' WHERE virtuemart_category_id={$r->virtuemart_category_id}");
$db->execute();
if ($db->getErrorNum()) {
echo $db->stderr(true);
die("112");
}
}
} else {
$db->setQuery("SELECT * FROM #__virtuemart_products_ru_ru ");
$rows = $db->loadObjectList();
if ($db->getErrorNum()) {
echo $db->stderr(true);
die("111");
}
foreach ($rows AS $r) {
$new_slug = translit($r->slug);
$db->setQuery("UPDATE #__virtuemart_products_ru_ru SET slug='$new_slug' WHERE virtuemart_product_id={$r->virtuemart_product_id}");
$db->execute();
if ($db->getErrorNum()) {
echo $db->stderr(true);
die("112");
}
}
}
die("555");