2013-05-07 62 views
1

比方說,我們必須保存在MySQL領域在一個表像,用戶代理這個從已保存的用戶代理檢測手機在MySQL只

表:訪問

ID(INT)

useragent(varchar 255)

假設我們保存了100k條記錄,我們必須找出它們中有多少條是移動的設備和計算機有多少,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; 
} 

} 
+0

如果您告訴我們您將如何使用PHP進行操作,這將有所幫助。 – fancyPants 2013-05-07 05:21:19

+0

在PHP中,我們將針對已知移動設備用戶代理列表運行正則表達式並獲得幾乎肯定的答案,但我不知道如何在不涉及PHP的情況下在MySQL查詢中運行這些多個正則表達式 – 2013-05-07 05:24:16

回答

0

我已經使用了下面的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