Обнаружение мобильного телефона из сохраненного пользовательского агента только в MySQL

Допустим, у нас есть пользовательские агенты, сохраненные в поле MySQL в такой таблице

Стол: визит

id (int)

useragent (varchar 255)

Допустим, у нас сохранено 100 000 записей, и мы должны выяснить, сколько из них являются мобильными устройствами и сколько компьютеров, есть ли способ в MySQL для запроса этой информации? Я знаю, как сделать это на PHP, и могу легко это сделать, но в этом случае нам нужно выяснить это из хранимых данных с помощью запроса и не использовать какой-либо язык программирования для анализа возвращаемых данных. Просто чистый MySQL

Например, в PHP вы можете использовать что-то вроде

function detectMobile() 
{

$mobile_browser = '0';

if (preg_match('/(up.browser|up.link|mmp|symbian|smartphone|midp|wap|phone|android)/i', strtolower($_SERVER['HTTP_USER_AGENT']))) {
    $mobile_browser++;
}

if ((strpos(strtolower($_SERVER['HTTP_ACCEPT']),'application/vnd.wap.xhtml+xml') > 0) or ((isset($_SERVER['HTTP_X_WAP_PROFILE']) or isset($_SERVER['HTTP_PROFILE'])))) {
    $mobile_browser++;
}    

$mobile_ua = strtolower(substr($_SERVER['HTTP_USER_AGENT'], 0, 4));
$mobile_agents = array(
    'w3c ','acs-','alav','alca','amoi','audi','avan','benq','bird','blac',
    'blaz','brew','cell','cldc','cmd-','dang','doco','eric','hipt','inno',
    'ipaq','java','jigs','kddi','keji','leno','lg-c','lg-d','lg-g','lge-',
    'maui','maxo','midp','mits','mmef','mobi','mot-','moto','mwbp','nec-',
    'newt','noki','oper','palm','pana','pant','phil','play','port','prox',
    'qwap','sage','sams','sany','sch-','sec-','send','seri','sgh-','shar',
    'sie-','siem','smal','smar','sony','sph-','symb','t-mo','teli','tim-',
    'tosh','tsm-','upg1','upsi','vk-v','voda','wap-','wapa','wapi','wapp',
    'wapr','webc','winw','winw','xda ','xda-');

if (in_array($mobile_ua,$mobile_agents)) {
    $mobile_browser++;
}

if (strpos(strtolower($_SERVER['ALL_HTTP']),'OperaMini') > 0) {
    $mobile_browser++;
}

if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'windows') > 0) {
    $mobile_browser = 0;
}

if(strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'ipad') > 0)
{
    $mobile_browser++;
}




if ($mobile_browser > 0) {
   return true;
}
else {
   return false;
}   

}

1 ответ

Я использовал ниже sql для подсчета количества или планшетов, мобильных и других устройств. Использовать Like запрос как более оптимизирован, чем с помощью регулярных выражений.

SELECT 
COUNT( * ) total, 
COUNT( IF( useragent LIKE '%tablet%' or useragent LIKE '%ipad%', 1, NULL ) ) AS tablets,
COUNT( IF( useragent LIKE '%mobile%' AND useragent NOT LIKE '%tablet%' AND useragent NOT LIKE '%ipad%', 1, NULL ) ) AS mobile,
COUNT( IF( useragent  NOT LIKE '%tablet%' AND useragent  NOT LIKE '%ipad%' AND useragent  NOT LIKE '%mobile%', 1, NULL ) ) AS other
FROM visit
Другие вопросы по тегам