當前位置: 首頁>>代碼示例>>PHP>>正文


PHP DbUtil::multipleInsert方法代碼示例

本文整理匯總了PHP中DbUtil::multipleInsert方法的典型用法代碼示例。如果您正苦於以下問題:PHP DbUtil::multipleInsert方法的具體用法?PHP DbUtil::multipleInsert怎麽用?PHP DbUtil::multipleInsert使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在DbUtil的用法示例。


在下文中一共展示了DbUtil::multipleInsert方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: processCountryCitySummary

function processCountryCitySummary($db, $dbNames, $startTime, $endTime, $hoursElapsedSinceLastEvenYear, $urlIdPageIdMap)
{
    $geoipProvider = CityIPSpatialDatabase::getInstance('geoip');
    $countryWiseLoadTimes = $cityWiseLoadTimes = $ipCountryCityMap = $countryCodeCountryIdMap = $cityNameCityIdMap = array();
    foreach ($urlIdPageIdMap as $urlId => $pageId) {
        $sql = 'SELECT ip_address, load_time.done AS loadTime
            FROM ' . $dbNames['main'] . '.main, ' . $dbNames['main'] . '.url, ' . $dbNames['main'] . '.url_static, ' . $dbNames['main'] . '.load_time
            WHERE main.url_id = url.url_id
            AND url.url_static_id = url_static.url_id
            AND main.main_id = load_time.main_id
            AND main.log_time >= :start_time AND main.log_time <= :end_time
            AND url_static.url_id = :url_id';
        $st = $db->prepare($sql);
        $st->bindValue(':start_time', $startTime, PDO::PARAM_STR);
        $st->bindValue(':end_time', $endTime, PDO::PARAM_STR);
        $st->bindValue(':url_id', $urlId, PDO::PARAM_INT);
        $st->execute();
        while ($row = $st->fetch(PDO::FETCH_ASSOC)) {
            $ipAddress = long2ip($row['ip_address']);
            if (!isset($ipCountryCityMap[$ipAddress])) {
                $geoipDetails = $geoipProvider->getLocationDetailsByIP($ipAddress);
                $ipCountryCityMap[$ipAddress] = array('country_code' => $geoipDetails['country_code'], 'city_name' => $geoipDetails['city_name']);
            }
            $countryCode = $ipCountryCityMap[$ipAddress]['country_code'];
            $cityName = $ipCountryCityMap[$ipAddress]['city_name'];
            if (!isset($countryCodeCountryIdMap[$countryCode])) {
                $sqlCountry = 'SELECT country_id FROM newmonk_common.country WHERE code = :code';
                $stCountry = $db->prepare($sqlCountry);
                $stCountry->bindValue(':code', $countryCode ? $countryCode : '', PDO::PARAM_STR);
                $stCountry->execute();
                $rowCountry = $stCountry->fetch(PDO::FETCH_ASSOC);
                $countryCodeCountryIdMap[$countryCode] = $rowCountry['country_id'];
                $stCountry->closeCursor();
            }
            $countryId = $countryCodeCountryIdMap[$countryCode];
            if (!isset($cityNameCityIdMap[$countryId][$cityName])) {
                $sqlCity = 'SELECT city_id
                    FROM newmonk_common.city
                    WHERE country_id = :country_id
                    AND name = :name';
                $stCity = $db->prepare($sqlCity);
                $stCity->bindValue(':country_id', $countryId, PDO::PARAM_INT);
                $stCity->bindValue(':name', $cityName ? $cityName : '', PDO::PARAM_STR);
                $stCity->execute();
                $rowCity = $stCity->fetch(PDO::FETCH_ASSOC);
                $cityNameCityIdMap[$countryId][$cityName] = $rowCity['city_id'];
                $stCity->closeCursor();
            }
            $cityId = $cityNameCityIdMap[$countryId][$cityName];
            $countryWiseLoadTimes[$urlId][$countryId][] = $row['loadTime'];
            $cityWiseLoadTimes[$urlId][$cityId][] = $row['loadTime'];
        }
        $st->closeCursor();
    }
    $countryWisePageViewsAndLoadTimes = $cityWisePageViewsAndLoadTimes = array();
    foreach ($urlIdPageIdMap as $urlId => $pageId) {
        foreach ($countryWiseLoadTimes[$urlId] as $countryId => $countryWiseLoadTime) {
            $countryWisePageViewsAndLoadTimes[$urlId][] = array('countryId' => $countryId, 'pageViews' => count($countryWiseLoadTime), 'loadTime' => round(array_sum($countryWiseLoadTime) / count($countryWiseLoadTime), 2));
        }
        foreach ($cityWiseLoadTimes[$urlId] as $cityId => $cityWiseLoadTime) {
            $cityWisePageViewsAndLoadTimes[$urlId][] = array('cityId' => $cityId, 'pageViews' => count($cityWiseLoadTime), 'loadTime' => round(array_sum($cityWiseLoadTime) / count($cityWiseLoadTime), 2));
        }
    }
    $numValuesToInsert = 0;
    $valuesToInsert = array();
    $queryPrefix = 'INSERT INTO ' . $dbNames['summary'] . '.country_summary(page_id, hours_elapsed_since_last_even_year, country_id, page_views, avg_load_time) VALUES';
    foreach ($urlIdPageIdMap as $urlId => $pageId) {
        foreach ($countryWisePageViewsAndLoadTimes[$urlId] as $countryWisePageViewsAndLoadTime) {
            if ($numValuesToInsert >= 5000) {
                DbUtil::multipleInsert($db, $queryPrefix, $valuesToInsert, 5);
                $numValuesToInsert = 0;
                $valuesToInsert = array();
            }
            ++$numValuesToInsert;
            $valuesToInsert[] = $pageId;
            $valuesToInsert[] = $hoursElapsedSinceLastEvenYear;
            $valuesToInsert[] = $countryWisePageViewsAndLoadTime['countryId'];
            $valuesToInsert[] = $countryWisePageViewsAndLoadTime['pageViews'];
            $valuesToInsert[] = $countryWisePageViewsAndLoadTime['loadTime'];
        }
    }
    DbUtil::multipleInsert($db, $queryPrefix, $valuesToInsert, 5);
    $numValuesToInsert = 0;
    $valuesToInsert = array();
    $queryPrefix = 'INSERT INTO ' . $dbNames['summary'] . '.city_summary(page_id, hours_elapsed_since_last_even_year, city_id, page_views, avg_load_time) VALUES';
    foreach ($urlIdPageIdMap as $urlId => $pageId) {
        foreach ($cityWisePageViewsAndLoadTimes[$urlId] as $cityWisePageViewsAndLoadTime) {
            if ($numValuesToInsert >= 5000) {
                DbUtil::multipleInsert($db, $queryPrefix, $valuesToInsert, 5);
                $numValuesToInsert = 0;
                $valuesToInsert = array();
            }
            ++$numValuesToInsert;
            $valuesToInsert[] = $pageId;
            $valuesToInsert[] = $hoursElapsedSinceLastEvenYear;
            $valuesToInsert[] = $cityWisePageViewsAndLoadTime['cityId'];
            $valuesToInsert[] = $cityWisePageViewsAndLoadTime['pageViews'];
            $valuesToInsert[] = $cityWisePageViewsAndLoadTime['loadTime'];
        }
    }
//.........這裏部分代碼省略.........
開發者ID:naukri-engineering,項目名稱:NewMonk,代碼行數:101,代碼來源:boomSummarizeLogs.php


注:本文中的DbUtil::multipleInsert方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。