extSourceStat_7Day_Orders.php

<?php

/** Log文件格式2012/7/4

列号 字段含义 取值
-------------------------------------------------------------------------
1 年月日时间
2 时间戳
3 记录类型 1:页面跳转 2:点击(不带来pv,uv,订单)
4 用户id 未登录:0
5 商品id 当前页是加入购物车或者商详,则取当前商品id,,否则:0
6 分站id
7 Guid 用户唯一表示串,进网站时生成
8 Tag 当前url中跟踪tag,没有则为空
9 Pageid 当前页面id
10 Page_level 当前页面level
11 url 当前页面url,不包含?及参数
12 ReferPageid 页面来源页面id,没有则0
13 Refer 页面来源url,没有则为空
14 Clientip 客户端ip
15 分辨率 客户端分辨率
16 颜色 页面颜色
17 Agent 客户端agent参数
-------------------------------------------------------------------------
**/

error_reporting(E_ALL);

require_once('Config.php');
require_once('ToolUtil.php');
require_once('Logger.php');

require_once('./constant.inc.php');

require_once('./bak_db_config.inc.php');

// 一级来源ID
define('DIRECT_LEVEL_1_ID', 66666);
define('DIRECT_LEVEL_1_NAME', '直接访问');

define('SEARCH_LEVEL_1_ID', 77777);
define('SEARCH_LEVEL_1_NAME', '搜索引擎');

define('CHANNEL_LEVEL_1_ID', 88888);
define('CHANNEL_LEVEL_1_NAME', '渠道推广');

define('OTHER_LEVEL_1_ID', 99999);
define('OTHER_LEVEL_1_NAME', '其他来源');

// TAG 系统页面来源ID
// 直接访问
define('SOURCE_ID_DIRECT', 0);
// 内部跳转
define('SOURCE_ID_INNER', -1);
// 其它来源
define('SOURCE_ID_OTHER', -2);

// 用于统计的ID
define('STAT_OTHER_LEVEL_2_ID', 44444);

// 在系统中未查到的推广TAG,默认设置为此ID
define('TAG_NOT_EXIST_SOURCE_ID', -33333);

// 渠道数据统计,代表全部的ID
define('CHANNEL_ALL_SOURCE_ID', -555);
define('CHANNEL_ALL_SOURCE_NAME', '全部');

$_searchSourceData = array(
14 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 14,
'level_2_name' => '百度',
),
24 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 24,
'level_2_name' => '谷歌',
),
34 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 24,
'level_2_name' => '谷歌',
),
44 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 44,
'level_2_name' => '搜搜',
),
54 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 54,
'level_2_name' => '搜狗',
),
64 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 64,
'level_2_name' => '有道',
),
74 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 74,
'level_2_name' => '必应',
),
84 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 84,
'level_2_name' => 'hao.qq.com',
),
94 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 94,
'level_2_name' => 'hao123.com',
),
104 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 104,
'level_2_name' => '2345.com',
),
114 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 114,
'level_2_name' => '114la.com',
),
124 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 124,
'level_2_name' => 'tao123.com',
),
134 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 134,
'level_2_name' => 'hao.360.cn',
),
144 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 144,
'level_2_name' => '123.sogou.com',
),
154 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 154,
'level_2_name' => '265.com',
),
164 => array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
'level_2_id' => 164,
'level_2_name' => 'etao.com',
),
174 => array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
'level_2_id' => 174,
'level_2_name' => '360',
),
);


$_sourceChannelData = array();
$_statSourceData_Level_1 = array();
$_statSourceData_Level_2 = array();
$_statSourceData_Level_3 = array();

$_tag_Level_1 = array();
$_tag_Level_2 = array();

// 用户订单数据
$_login_order_data = array();

// 生成外投推广来源ID
function _getLevel3TagID($level_1_id, $level_2_id, $level_3_id)
{
$tag_source_id = $level_3_id + $level_2_id * 100000 + $level_1_id * 10000000;
$tag_source_id = $tag_source_id * 10 + PAGE_TYPE_EXT_PROMOTION;

return "{$tag_source_id}";
}

function _getSourceChannelData()
{
GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

GLOBAL $_tag_Level_1;
GLOBAL $_tag_Level_2;

$mysql = ToolUtil::getDBObj('icson');
if (false === $mysql) {
Logger::err("Get mysql db [icson] failed: " . ToolUtil::$errMsg . "\n");

return false;
}

$table_name = "t_tag_source";
$sqlstmt_level_0 = "SELECT s_name, tag_id FROM {$table_name} WHERE s_level = 0";
$sqlstmt_level_1 = "SELECT s_name, tag_fid, level_1_id FROM {$table_name} WHERE s_level = 1";
$sqlstmt_level_2 = "SELECT s_name, level_1_id, level_2_id FROM {$table_name} WHERE s_level = 2";
$sqlstmt_level_3 = "SELECT s_name, level_1_id, level_2_id, level_3_id FROM {$table_name} WHERE s_level = 3";

$level_0_data = array();
$level_1_data = array();
$level_2_data = array();
$level_3_data = array();

// get level 0
$rows = $mysql->getRows($sqlstmt_level_0);
if (false === $rows) {
Logger::err("Query mysql db [icson].[{$table_name}] failed: " . $mysql->errMsg . "\n");

return false;
}
else {
foreach ($rows as &$row) {
$level_0_data[$row['tag_id']] = $row;

$_statSourceData_Level_2[intval($row['tag_id'])] = array(
'level_2_id' => intval($row['tag_id']),
'level_2_name' => $row['s_name'],

'level_1_id' => CHANNEL_LEVEL_1_ID,
'level_1_name' => CHANNEL_LEVEL_1_NAME,
);
}
}

// get level 1
$rows = $mysql->getRows($sqlstmt_level_1);
if (false === $rows) {
Logger::err("Query mysql db [icson].[{$table_name}] failed: " . $mysql->errMsg . "\n");

return false;
}
else {
foreach ($rows as &$row) {
$level_1_data[$row['level_1_id']] = $row;
}
}

// get level 2
$rows = $mysql->getRows($sqlstmt_level_2);
if (false === $rows) {
Logger::err("Query mysql db [icson].[{$table_name}] failed: " . $mysql->errMsg . "\n");

return false;
}
else {
foreach ($rows as &$row) {
$level_2_data[$row['level_1_id']][$row['level_2_id']] = $row;
}
}

// get level 3
$rows = $mysql->getRows($sqlstmt_level_3);
if (false === $rows) {
Logger::err("Query mysql db [icson].[{$table_name}] failed: " . $mysql->errMsg . "\n");

return false;
}
else {
foreach ($rows as &$row) {
$tag_source_id = _getLevel3TagID($row['level_1_id'], $row['level_2_id'], $row['level_3_id']);
$level_3_data[$tag_source_id] = $row;
}
}

// 获取TAG映射数据
foreach ($level_3_data as $tag_source_id => &$tag_data) {
$tag_level_1_id = $tag_data['level_1_id'];
$tag_level_2_id = $tag_data['level_2_id'];
$tag_level_3_id = $tag_data['level_3_id'];

$tag_level_1_name = $level_1_data[$tag_level_1_id]['s_name'];
$tag_level_2_name = $level_2_data[$tag_level_1_id][$tag_level_2_id]['s_name'];
$tag_level_3_name = $tag_data['s_name'];

$level_3_id = $tag_level_1_id;
$level_2_id = $level_1_data[$tag_level_1_id]['tag_fid'];
$level_1_id = CHANNEL_LEVEL_1_ID;

$level_3_name = $tag_level_1_name;
$level_2_name = $level_0_data[$level_2_id]['s_name'];
$level_1_name = CHANNEL_LEVEL_1_NAME;

$_sourceChannelData[$tag_source_id] = array(
// TAG 系统level
'tag_level_1_id' => $tag_level_1_id,
'tag_level_2_id' => $tag_level_2_id,
'tag_level_3_id' => $tag_level_3_id,

'tag_level_1_name' => $tag_level_1_name,
'tag_level_2_name' => $tag_level_2_name,
'tag_level_3_name' => $tag_level_3_name,

// 统计结果level
'level_1_id' => $level_1_id,
'level_2_id' => $level_2_id,
'level_3_id' => $level_3_id,

'level_1_name' => $level_1_name,
'level_2_name' => $level_2_name,
'level_3_name' => $level_3_name,
);

// tag level 1
$_tag_Level_1[$tag_level_1_id] = array(
'tag_level_1_id' => $tag_level_1_id,

'tag_level_1_name' => $tag_level_1_name,
);

// tag level 2
$_tag_Level_2[$tag_level_1_id][$tag_level_2_id] = array(
'tag_level_1_id' => $tag_level_1_id,
'tag_level_2_id' => $tag_level_2_id,

'tag_level_1_name' => $tag_level_1_name,
'tag_level_2_name' => $tag_level_2_name,
);

// stat level 3 data
$_statSourceData_Level_3[$level_3_id] = array(
'level_1_id' => $level_1_id,
'level_2_id' => $level_2_id,
'level_3_id' => $level_3_id,

'level_1_name' => $level_1_name,
'level_2_name' => $level_2_name,
'level_3_name' => $level_3_name,
);
}

// 直接访问
$_sourceChannelData[SOURCE_ID_DIRECT] = array(
// 统计结果level
'level_1_id' => DIRECT_LEVEL_1_ID,
'level_1_name' => DIRECT_LEVEL_1_NAME,
);

// 其它来源
$_sourceChannelData[SOURCE_ID_OTHER] = array(
// 统计结果level
'level_2_id' => STAT_OTHER_LEVEL_2_ID,
'level_2_name' => '其它',

'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
);

return true;
}

function _getStatSourceData_Level_X()
{
GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;

GLOBAL $_searchSourceData;

// get level 1
$_statSourceData_Level_1[CHANNEL_LEVEL_1_ID] = array(
'level_1_id' => CHANNEL_LEVEL_1_ID,
'level_1_name' => CHANNEL_LEVEL_1_NAME,
);

$_statSourceData_Level_1[DIRECT_LEVEL_1_ID] = array(
'level_1_id' => DIRECT_LEVEL_1_ID,
'level_1_name' => DIRECT_LEVEL_1_NAME,
);

$_statSourceData_Level_1[SEARCH_LEVEL_1_ID] = array(
'level_1_id' => SEARCH_LEVEL_1_ID,
'level_1_name' => SEARCH_LEVEL_1_NAME,
);

$_statSourceData_Level_1[OTHER_LEVEL_1_ID] = array(
'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
);

// get level 2
foreach ($_searchSourceData as $source_id => $source_data) {
$_statSourceData_Level_2[$source_id] = $source_data;
}

$_statSourceData_Level_2[STAT_OTHER_LEVEL_2_ID] = array(
'level_2_id' => STAT_OTHER_LEVEL_2_ID,
'level_2_name' => '其它',

'level_1_id' => OTHER_LEVEL_1_ID,
'level_1_name' => OTHER_LEVEL_1_NAME,
);

return true;
}

function _getOrderUserFirstOrderDate($order_users) {
$user_first_order_date = array();

$user_ids = array();
$mssql = false;

foreach ($order_users as $user_id => $dummy_val) {
$user_ids[] = $user_id;

if (count($user_ids) >= 500) {
$sql_stmt = "SELECT user_id, CONVERT(VARCHAR, first_order_date, 112) first_order_date FROM t_aggregation_user_first_order_date ";
$sql_stmt .= "WHERE user_id IN (" . implode(",", $user_ids) . ")";

$rows = _getRowsWithRetries('USER_ORDER', $sql_stmt, $mssql);
if (false !== $rows) {
foreach ($rows as $row) {
$user_first_order_date[$row['user_id']] = $row['first_order_date'];
}
}

$user_ids = array();
}
}

if (count($user_ids) > 0) {
$sql_stmt = "SELECT user_id, CONVERT(VARCHAR, first_order_date, 112) first_order_date FROM t_aggregation_user_first_order_date ";
$sql_stmt .= "WHERE user_id IN (" . implode(",", $user_ids) . ")";

$rows = _getRowsWithRetries('USER_ORDER', $sql_stmt, $mssql);
if (false !== $rows) {
foreach ($rows as $row) {
$user_first_order_date[$row['user_id']] = $row['first_order_date'];
}
}

$user_ids = array();
}

echo "Get user first order date: count: ", count($user_first_order_date), "\n";

return $user_first_order_date;
}

function _mergeOrderData(&$order_data, $access_key, $user_id, $user_type, $row)
{
if (!isset($order_data[$access_key])) {
$order_data[$access_key] = array();
}

if (!isset($order_data[$access_key][$user_type])) {
$order_data[$access_key][$user_type] = array();
}

if (!isset($order_data[$access_key][$user_type][$user_id])) {
$order_data[$access_key][$user_type][$user_id] = array();
}

if (!isset($order_data[$access_key][$user_type][$user_id]['order_ids'])) {
$order_data[$access_key][$user_type][$user_id]['order_ids'] = array();
}

if (!isset($order_data[$access_key][$user_type][$user_id]['order_ids'][$row['OId']])) {
$order_data[$access_key][$user_type][$user_id]['order_ids'][$row['OId']] = array();

$order_data[$access_key][$user_type][$user_id]['order_ids'][$row['OId']]['Qty'] = 0;
$order_data[$access_key][$user_type][$user_id]['order_ids'][$row['OId']]['OFee'] = 0.0;
}

// 当日下单的订单
$order_data[$access_key][$user_type][$user_id]['order_ids'][$row['OId']]['Qty'] += intval($row['Qty']);
$order_data[$access_key][$user_type][$user_id]['order_ids'][$row['OId']]['OFee'] += floatval($row['OFee']);

return true;
}

function _getSourceOrdersData($s_date)
{
GLOBAL $_login_order_data;

$date_start = $s_date;
$date_end = date("Y-m-d", strtotime("+1 day", strtotime($date_start)));
$date_intstr = date('Ymd', strtotime($s_date));

// 当日下单的订单数据
$order_data = array();
// 出库订单数据
$outstock_data = array();

// 订单ID对应的SourceID
$order_sourceid = array();

$sql_stmt = <<<SQL_STMT
-- SELECT ISNULL(OTag, '') as OTag,
-- SO_Item.SOSysNo as OId,
-- CONVERT(VARCHAR, SO_Master.OrderDate, 112) OrderDate,
-- Quantity as Qty,
-- (Price * Quantity) as OFee,
-- SO_Master.CustomerSysNo as UId,
-- (CASE WHEN SO_Master.SalesManSysNo = 666666 THEN 1999 ELSE SO_Master.SiteNo END) as wh_id
-- from t_deal td 
-- left join t_trade tr on td.Fdeal_id = tr.fdeal_id
--	left join etl_users..t_user_buyer u on u.Fwg_uid=td.Fbuyer_id
-- where td.Fdeal_gen_time >= '{$date_start}' AND td.Fdeal_gen_time < '{$date_end}' and td.Fdeal_property3 = 64

SELECT ISNULL(tr.ext_11002, '') as OTag,
td.Fbusiness_deal_id as OId,
CONVERT(VARCHAR, td.Fdeal_gen_time, 112) OrderDate,
tr.Ftrade_buy_num as Qty,
(tr.Ftrade_buy_num*tr.Ftrade_buy_price / 100.00) as OFee,
ISNULL(u.Ficson_uid,0) as UId,
(case when td.Fdeal_source in(2,3,8) then 1999 else td.fsite_id end) as wh_id
from t_deal td 
left join t_trade tr on td.Fdeal_id = tr.fdeal_id
left join etl_users..t_user_buyer u on u.Fwg_uid=td.Fbuyer_id
where td.Fdeal_gen_time >= '{$date_start}' AND td.Fdeal_gen_time < '{$date_end}' and td.Fdeal_property3 = 64

SQL_STMT;

$sql_stmt_out = <<<SQL_STMT_OUT
--SELECT ISNULL(OTag, '') as OTag,
-- SO_Item.SOSysNo as OId,
-- CONVERT(VARCHAR, SO_Master.OrderDate, 112) OrderDate,
-- Quantity as Qty,
-- (Price * Quantity) as OFee,
-- SO_Master.CustomerSysNo as UId,
-- (CASE WHEN SO_Master.SalesManSysNo = 666666 THEN 1999 ELSE SO_Master.SiteNo END) as wh_id
--FROM SO_Item
--INNER JOIN SO_Master ON SO_Item.SOSysNo = SO_Master.SysNo
--WHERE SO_Master.OutTime >= '{$date_start}' AND SO_Master.OutTime < '{$date_end}'
-- AND SO_Master.Status IN (4, -4, -5)
-- AND SO_Master.SalesManSysNo NOT IN (10, 7611007, 888888, 999999, 999888, 999998)
-- AND SO_Item.ProductType = 0

SELECT ISNULL(tr.ext_11002, '') as OTag,
td.Fbusiness_deal_id as OId,
CONVERT(VARCHAR, td.Fdeal_gen_time, 112) OrderDate,
tr.Ftrade_buy_num as Qty,
(tr.Ftrade_buy_num*tr.Ftrade_buy_price / 100.00) as OFee,
ISNULL(u.Ficson_uid,0) as UId,
(case when td.Fdeal_source in(2,3,8) then 1999 else td.fsite_id end) as wh_id
from t_deal td
left join t_trade tr on td.Fdeal_id = tr.fdeal_id
left join etl_users..t_user_buyer u on u.Fwg_uid=td.Fbuyer_id
where td.Fdeal_seller_consign_time >= '{$date_start}' AND td.Fdeal_seller_consign_time < '{$date_end}' and tr.Ftrade_state IN (3,4,9)
and td.Fdeal_property3 = 64

SQL_STMT_OUT;

// 获取订单数据
$mssql = false;
$order_rows = _getRowsWithRetries('ETL0_ICSONJD_ORDERS', $sql_stmt, $mssql);

// 查询数据失败
if (false === $order_rows) {
return false;
}

// 查询数据失败
if (false === $order_rows || empty($order_rows)) {
Logger::err("get order data [ERP_SYNC_{$site_id}] failed:" . $mssql->errMsg . "\n");

return false;
}

// 获取当日出库的订单数据
$outstock_rows = _getRowsWithRetries('ETL0_ICSONJD_ORDERS', $sql_stmt_out, $mssql);

// 查询数据失败
if (false === $outstock_rows) {
Logger::err("get out stock order data [ERP_SYNC_{$site_id}] failed:" . $mssql->errMsg . "\n");

return false;
}

// Step 1.0: Get user first order date
$order_users = array();
foreach ($order_rows as &$row) {
$order_users[$row['UId']] = 0;
}
$user_first_order_date = _getOrderUserFirstOrderDate($order_users);

// Step 1.1: 获取订单外部来源
foreach ($order_rows as &$row) {
$order_id = $row['OId'];
$user_id = intval($row['UId']);

$source_id = SOURCE_ID_DIRECT;

if (isset($order_sourceid[$order_id])) {
continue;
}

// 订单跟踪码格式:0级页面tag-1级页面tag-2级页面tag-3级页面tag.level
$tags = explode("-", $row['OTag']);
if (!isset($tags[3])) {
continue;
}
else {
$source_id = (int) (intval($tags[0]) / 100000);
if($source_id < 0){
continue;
}
}

// 非法的Source ID算作其它来源
if ( ($source_id > 0) &&
($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) &&
($source_id % 10 != PAGE_TYPE_EXT_SEARCH) ) {

continue;
}

// 到这里已经可以确定是外部来源
if ($source_id > 0) {
$order_sourceid[$order_id] = $source_id;
}
}

foreach ($order_rows as &$row) {
$source_id = -99999;
$tags = explode("-", $row['OTag']);
if (isset($tags[3])) {
$source_id = (int) (intval($tags[0]) / 100000);
if($source_id < 0){
$source_id = -99999;
}
// 非法的Source ID算作其它来源
else if ( ($source_id > 0) &&
($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) &&
($source_id % 10 != PAGE_TYPE_EXT_SEARCH) ) {

$source_id = -99999;
}
}

if (-99999 == $source_id) {
$order_id = $row['OId'];
if (isset($order_sourceid[$order_id])) {
$source_id = $order_sourceid[$order_id];
}
else {
continue;
}
}

$wh_id = intval($row['wh_id']);
$user_id = intval($row['UId']);

$access_key = "{$wh_id}_{$source_id}";
$access_allwh_key = "0_{$source_id}";

$uid = $row['UId'];
$user_type = USER_TYPE_NEW;
if (isset($user_first_order_date[$uid])) {
$user_type = ($user_first_order_date[$uid] == $row['OrderDate']) ? USER_TYPE_NEW : USER_TYPE_RETURN;
}

_mergeOrderData($order_data, $access_key, $user_id, $user_type, $row);
_mergeOrderData($order_data, $access_allwh_key, $user_id, $user_type, $row);
} // end of foreach ($rows as $row) ...

// Step 2.0: Get user first order date
$order_users = array();
foreach ($outstock_rows as &$row) {
$order_users[$row['UId']] = 0;
}
$user_first_order_date = _getOrderUserFirstOrderDate($order_users);

// Step 2.1: 获取订单外部来源
foreach ($outstock_rows as &$row) {
$order_id = $row['OId'];
$user_id = intval($row['UId']);

$source_id = SOURCE_ID_DIRECT;

if (isset($order_sourceid[$order_id])) {
continue;
}

// 订单跟踪码格式:0级页面tag-1级页面tag-2级页面tag-3级页面tag.level
$tags = explode("-", $row['OTag']);
if (!isset($tags[3])) {
continue;
}
else {
$source_id = (int) (intval($tags[0]) / 100000);
if($source_id < 0){
continue;
}
}

// 非法的Source ID算作其它来源
if ( ($source_id > 0) &&
($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) &&
($source_id % 10 != PAGE_TYPE_EXT_SEARCH) ) {

continue;
}

// 到这里已经可以确定是外部来源
if ($source_id > 0) {
$order_sourceid[$order_id] = $source_id;
}
}

foreach ($outstock_rows as &$row) {
$source_id = -99999;
$tags = explode("-", $row['OTag']);
if (isset($tags[3])) {
$source_id = (int) (intval($tags[0]) / 100000);
if($source_id < 0){
$source_id = -99999;
}
// 非法的Source ID算作其它来源
else if ( ($source_id > 0) &&
($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) &&
($source_id % 10 != PAGE_TYPE_EXT_SEARCH) ) {

$source_id = -99999;
}
}

if (-99999 == $source_id) {
$order_id = $row['OId'];
if (isset($order_sourceid[$order_id])) {
$source_id = $order_sourceid[$order_id];
}
else {
continue;
}
}

$wh_id = intval($row['wh_id']);
$user_id = intval($row['UId']);

$access_key = "{$wh_id}_{$source_id}";
$access_allwh_key = "0_{$source_id}";

$uid = $row['UId'];
$user_type = USER_TYPE_NEW;
if (isset($user_first_order_date[$uid])) {
$user_type = ($user_first_order_date[$uid] == $row['OrderDate']) ? USER_TYPE_NEW : USER_TYPE_RETURN;
}

_mergeOrderData($outstock_data, $access_key, $user_id, $user_type, $row);
_mergeOrderData($outstock_data, $access_allwh_key, $user_id, $user_type, $row);
} // end of foreach ($rows as $row) ...

// 当日下单的订单数据
foreach ($order_data as $access_key => &$access_data) {
foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
$order_num = 0;
$order_product_num = 0;
$order_fee = 0.0;
if (isset($user_data['order_ids'])) {
$order_num = count($user_data['order_ids']);
foreach ($user_data['order_ids'] as $order_id => &$single_order_data) {
$order_product_num += intval($single_order_data['Qty']);
$order_fee += floatval($single_order_data['OFee']);
}
}

if (!isset($_login_order_data[$access_key])) {
$_login_order_data[$access_key] = array();
}

if (!isset($_login_order_data[$access_key][$user_type])) {
$_login_order_data[$access_key][$user_type] = array();
}

if (!isset($_login_order_data[$access_key][$user_type][$user_id])) {
$_login_order_data[$access_key][$user_type][$user_id] = array();
}

$_login_order_data[$access_key][$user_type][$user_id]['order_num'] = $order_num;
$_login_order_data[$access_key][$user_type][$user_id]['order_product_num'] = $order_product_num;
$_login_order_data[$access_key][$user_type][$user_id]['order_fee'] = $order_fee;
}
} // end of foreach ($access_data as $user_type => &$users) { ...
} // end of foreach ($order_data as $access_key => &$access_data) { ...

// 出库订单数据
foreach ($outstock_data as $access_key => &$access_data) {
foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
$out_num = 0;
$out_product_num = 0;
$out_fee = 0.0;
if (isset($user_data['order_ids'])) {
$out_num = count($user_data['order_ids']);
foreach ($user_data['order_ids'] as $order_id => &$single_order_data) {
$out_product_num += intval($single_order_data['Qty']);
$out_fee += floatval($single_order_data['OFee']);
}
}

if (!isset($_login_order_data[$access_key])) {
$_login_order_data[$access_key] = array();
}

if (!isset($_login_order_data[$access_key][$user_type])) {
$_login_order_data[$access_key][$user_type] = array();
}

if (!isset($_login_order_data[$access_key][$user_type][$user_id])) {
$_login_order_data[$access_key][$user_type][$user_id] = array();
}

$_login_order_data[$access_key][$user_type][$user_id]['out_num'] = $out_num;
$_login_order_data[$access_key][$user_type][$user_id]['out_product_num'] = $out_product_num;
$_login_order_data[$access_key][$user_type][$user_id]['out_fee'] = $out_fee;
}
} // end of foreach ($access_data as $user_type => $users) { ...
} // end of foreach ($outstock_data as $access_key => &$access_data) { ...

$mssql = false;

return true;
}

function _generalUpdateResultPVOrderData(&$result_data, &$source_key, &$pv_order_data) {
$order_num = isset($pv_order_data['order_num']) ? $pv_order_data['order_num'] : 0;
$order_product_num = isset($pv_order_data['order_product_num']) ? $pv_order_data['order_product_num'] : 0;
$order_fee = isset($pv_order_data['order_fee']) ? $pv_order_data['order_fee'] : 0.0;

$out_num = isset($pv_order_data['out_num']) ? $pv_order_data['out_num'] : 0;
$out_product_num = isset($pv_order_data['out_product_num']) ? $pv_order_data['out_product_num'] : 0;
$out_fee = isset($pv_order_data['out_fee']) ? $pv_order_data['out_fee'] : 0.0;

if (!isset($result_data[$source_key])) {
$result_data[$source_key] = array();

$result_data[$source_key]['order_num'] = 0;
$result_data[$source_key]['order_product_num'] = 0;
$result_data[$source_key]['order_fee'] = 0.0;

$result_data[$source_key]['out_num'] = 0;
$result_data[$source_key]['out_product_num'] = 0;
$result_data[$source_key]['out_fee'] = 0.0;
}

// 下单数据
$result_data[$source_key]['order_num'] += $order_num;
$result_data[$source_key]['order_product_num'] += $order_product_num;
$result_data[$source_key]['order_fee'] += $order_fee;

$result_data[$source_key]['out_num'] += $out_num;
$result_data[$source_key]['out_product_num'] += $out_product_num;
$result_data[$source_key]['out_fee'] += $out_fee;

return true;
}

function _getChannelSourceResultData(&$channel_source_result_data)
{
GLOBAL $_login_order_data;

// Step 2: 获取已登录用户的数据
// 包括新老用户,未下过订单的用户算新用户
$order_users_data = array();
$outstock_users_data = array();

// Get order data
foreach ($_login_order_data as $access_key => &$access_data) {
// $access_key 格式: 分站ID_来源ID
$key_array = explode("_", $access_key);
if (!isset($key_array[1])) {
continue;
}

$source_id = $key_array[1];
// 只获取外投推广数据
if ($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) {
continue;
}

foreach ($access_data as $user_type => &$users) {
$source_key = "{$access_key}_{$user_type}";

foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($channel_source_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
}
} // end of foreach ($access_data as $user_type => &$users) { ...
} // end of foreach ($_login_order_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => $source_data) {
$order_user_num = count($source_data);

$channel_source_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => $source_data) {
$out_user_num = count($source_data);

$channel_source_result_data[$source_key]['out_user_num'] = $out_user_num;
}

// Get order data
foreach ($_login_order_data as $access_key => &$access_data) {
// $access_key 格式: 分站ID_来源ID
$key_array = explode("_", $access_key);
if (!isset($key_array[1])) {
continue;
}

$source_id = $key_array[1];
// 只获取外投推广数据
if ($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) {
continue;
}

$user_type = USER_TYPE_ALL;

$source_key = "{$access_key}_{$user_type}";

foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($channel_source_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
}
} // end of foreach ($access_data as $user_type => &$users) { ...
} // end of foreach ($_login_order_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => $source_data) {
$order_user_num = count($source_data);

$channel_source_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => $source_data) {
$out_user_num = count($source_data);

$channel_source_result_data[$source_key]['out_user_num'] = $out_user_num;
}

$order_users_data = null;
$outstock_users_data = null;

return true;
}

function _storeChannelSourceResultData($s_date, &$channel_source_result_data)
{
GLOBAL $_sourceChannelData;

// 写入点击流DB
$mssql = false;
$db_name = 'ICSON_STATISTICS_CLICKFLOW';

$table_name = "t_aggregation_daily_ext_source_channel_rawdata_test2";

// $channel_source_result_data 格式: 分站ID_来源ID_用户类型
foreach ($channel_source_result_data as $source_key => &$source_data) {
$key_array = explode("_", $source_key);
if (!isset($key_array[2])) {
continue;
}

$wh_id = $key_array[0];
$source_id = $key_array[1];
$user_type = $key_array[2];

$level_1_id = isset($_sourceChannelData[$source_id]['tag_level_1_id']) ? $_sourceChannelData[$source_id]['tag_level_1_id'] : 0;
$level_2_id = isset($_sourceChannelData[$source_id]['tag_level_2_id']) ? $_sourceChannelData[$source_id]['tag_level_2_id'] : 0;
$level_3_id = isset($_sourceChannelData[$source_id]['tag_level_3_id']) ? $_sourceChannelData[$source_id]['tag_level_3_id'] : 0;

$order_num = isset($source_data['order_num']) ? $source_data['order_num'] : 0;
$order_product_num = isset($source_data['order_product_num']) ? $source_data['order_product_num'] : 0;
$order_fee = isset($source_data['order_fee']) ? $source_data['order_fee'] : 0.0;
$order_user_num = isset($source_data['order_user_num']) ? $source_data['order_user_num'] : 0;

$out_num = isset($source_data['out_num']) ? $source_data['out_num'] : 0;
$out_product_num = isset($source_data['out_product_num']) ? $source_data['out_product_num'] : 0;
$out_fee = isset($source_data['out_fee']) ? $source_data['out_fee'] : 0.0;
$out_user_num = isset($source_data['out_user_num']) ? $source_data['out_user_num'] : 0;

$condition = "s_date='{$s_date}' and warehouse_id={$wh_id} and level_1_id={$level_1_id} and level_2_id={$level_2_id} and level_3_id={$level_3_id} ";
$condition .= "and source_id={$source_id} and user_type={$user_type}";

$row = array(
'order_num_7day' => $order_num,
'order_product_num_7day' => $order_product_num,
'order_fee_7day' => $order_fee,
'order_user_num_7day' => $order_user_num,

'out_num_7day' => $out_num,
'out_product_num_7day' => $out_product_num,
'out_fee_7day' => $out_fee,
'out_user_num_7day' => $out_user_num,
);

var_dump($db_name);
$ret = _updateWithRetries($db_name, $table_name, $row, $condition, $mssql);
var_dump($ret);
if (false === $ret) {
Logger::err("Update source channel stat data failed");

continue;
}
} // end of foreach ($channel_source_result_data as $source_key => &$source_data) { ...

return true;
}

/////////////////////////////////////////////////////////////////////////////////////////////////////////
// 获取三级数据
/////////////////////////////////////////////////////////////////////////////////////////////////////////

// 只有渠道推广才有三级统计数据
function _getStatL3ResultData(&$stat_level_3_result_data)
{
GLOBAL $_login_order_data;

GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

// 获取订单数据
$login_level_3_order_data = array();
foreach ($_login_order_data as $access_key => &$access_data) {
// $access_key 格式: 分站ID_来源ID
$key_array = explode("_", $access_key);
if (!isset($key_array[1])) {
continue;
}

$wh_id = $key_array[0];
$source_id = $key_array[1];
// 只获取外投推广数据
if ($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) {
continue;
}

if (!isset($_sourceChannelData[$source_id])) {
continue;
}
$level_3_id = $_sourceChannelData[$source_id]['level_3_id'];

$l3_access_key = "{$wh_id}_{$level_3_id}";

foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$order_product_num = isset($user_data['order_product_num']) ? $user_data['order_product_num'] : 0;
$order_fee = isset($user_data['order_fee']) ? $user_data['order_fee'] : 0.0;

$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;
$out_product_num = isset($user_data['out_product_num']) ? $user_data['out_product_num'] : 0;
$out_fee = isset($user_data['out_fee']) ? $user_data['out_fee'] : 0.0;

if (!isset($login_level_3_order_data[$l3_access_key])) {
$login_level_3_order_data[$l3_access_key] = array();
}

if (!isset($login_level_3_order_data[$l3_access_key][$user_type])) {
$login_level_3_order_data[$l3_access_key][$user_type] = array();
}

if (!isset($login_level_3_order_data[$l3_access_key][$user_type][$user_id])) {
$login_level_3_order_data[$l3_access_key][$user_type][$user_id] = array();

$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['order_num'] = 0;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['order_product_num'] = 0;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['order_fee'] = 0;

$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['out_num'] = 0;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['out_product_num'] = 0;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['out_fee'] = 0;
}

// 订单数据
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['order_num'] += $order_num;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['order_product_num'] += $order_product_num;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['order_fee'] += $order_fee;

// 出库订单数据
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['out_num'] += $out_num;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['out_product_num'] += $out_product_num;
$login_level_3_order_data[$l3_access_key][$user_type][$user_id]['out_fee'] += $out_fee;
} // end of foreach ($users as $user_id => &$user_data) { ...
} // end of foreach ($access_data as $user_type => $users) { ...
} // end of foreach ($_login_order_data as $access_key => &$access_data) { ...

// Step 2.1: 获取已登录用户的数据
// 包括新老用户,未下过订单的用户算作新用户
$order_users_data = array();
$outstock_users_data = array();

// Get order data
foreach ($login_level_3_order_data as $l3_access_key => &$l3_access_data) {
// $l3_access_key 格式: 分站ID_三级来源ID
foreach ($l3_access_data as $user_type => &$users) {
$source_key = "{$l3_access_key}_{$user_type}";

foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($stat_level_3_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
}
} // end of foreach ($$l3_access_data as $user_type => &$users) { ...
} // end of foreach ($login_level_3_order_data as $l3_access_key => &$l3_access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$stat_level_3_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$stat_level_3_result_data[$source_key]['out_user_num'] = $out_user_num;
}

// Step 2.2: 获取已登录用户的数据
// 包括新老用户,且包括未下过订单的用户
$order_users_data = array();
$outstock_users_data = array();

// Get order data
foreach ($login_level_3_order_data as $l3_access_key => &$l3_access_data) {
// $l2_access_key 格式: 分站ID_三级来源ID
$user_type = USER_TYPE_ALL;
$source_key = "{$l3_access_key}_{$user_type}";

foreach ($l3_access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($stat_level_3_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($users as $user_id => &$user_data) { ...
} // end of foreach ($l3_access_data as $user_type => &$users) { ...
} // end of foreach ($login_level_3_order_data as $l3_access_key => &$l3_access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$stat_level_3_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$stat_level_3_result_data[$source_key]['out_user_num'] = $out_user_num;
}

return true;
}

// 只有渠道推广才有三级统计数据
function _storeStatL3ResultData($s_date, &$stat_level_3_result_data)
{
GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

// 写入点击流DB
$mssql = false;
$db_name = 'ICSON_STATISTICS_CLICKFLOW';

$table_name = "t_aggregation_daily_ext_source_level_3_test2";

// $stat_level_3_result_data 格式: 分站ID_三级来源ID_用户类型
foreach ($stat_level_3_result_data as $source_key => &$source_data) {
$key_array = explode("_", $source_key);
if (!isset($key_array[2])) {
continue;
}

$wh_id = $key_array[0];
$level_3_id = $key_array[1];
$user_type = $key_array[2];

$level_1_id = $_statSourceData_Level_3[$level_3_id]['level_1_id'];
$level_2_id = $_statSourceData_Level_3[$level_3_id]['level_2_id'];

$order_num = isset($source_data['order_num']) ? $source_data['order_num'] : 0;
$order_product_num = isset($source_data['order_product_num']) ? $source_data['order_product_num'] : 0;
$order_fee = isset($source_data['order_fee']) ? $source_data['order_fee'] : 0.0;
$order_user_num = isset($source_data['order_user_num']) ? $source_data['order_user_num'] : 0;

$out_num = isset($source_data['out_num']) ? $source_data['out_num'] : 0;
$out_product_num = isset($source_data['out_product_num']) ? $source_data['out_product_num'] : 0;
$out_fee = isset($source_data['out_fee']) ? $source_data['out_fee'] : 0.0;
$out_user_num = isset($source_data['out_user_num']) ? $source_data['out_user_num'] : 0;

$condition = "s_date='{$s_date}' and warehouse_id={$wh_id} and level_1_id={$level_1_id} and level_2_id={$level_2_id} and level_3_id={$level_3_id} ";
$condition .= "and user_type={$user_type}";

$row = array(
'order_num_7day' => $order_num,
'order_product_num_7day' => $order_product_num,
'order_fee_7day' => $order_fee,
'order_user_num_7day' => $order_user_num,

'out_num_7day' => $out_num,
'out_product_num_7day' => $out_product_num,
'out_fee_7day' => $out_fee,
'out_user_num_7day' => $out_user_num,
);

$ret = _updateWithRetries($db_name, $table_name, $row, $condition, $mssql);
if (false === $ret) {
Logger::err("Update source channel stat data failed");

continue;
}
} // end of foreach ($stat_level_3_result_data as $source_key => &$source_data) { ...

return true;
}

/////////////////////////////////////////////////////////////////////////////////////////////////////////
// 获取二级数据
/////////////////////////////////////////////////////////////////////////////////////////////////////////

function _getStatL2ResultData(&$stat_level_2_result_data)
{
GLOBAL $_login_order_data;

GLOBAL $_sourceChannelData;
GLOBAL $_searchSourceData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

$login_level_2_order_data = array();
foreach ($_login_order_data as $access_key => &$access_data) {
// $access_key 格式: 分站ID_来源ID
$key_array = explode("_", $access_key);
if (!isset($key_array[1])) {
continue;
}

$wh_id = $key_array[0];
$source_id = $key_array[1];

$level_2_id = STAT_OTHER_LEVEL_2_ID;

// 直接访问处于一级
if (SOURCE_ID_DIRECT == $source_id) {
continue;
}

// 外投推广数据
if (SOURCE_ID_OTHER == $source_id) {
$level_2_id = STAT_OTHER_LEVEL_2_ID;
}
else if ($source_id % 10 == PAGE_TYPE_EXT_PROMOTION) {
if (!isset($_sourceChannelData[$source_id])) {
echo "Promotion Source: {$source_id} Not Exists!\n";
continue;
}
$level_2_id = $_sourceChannelData[$source_id]['level_2_id'];
}
else if ($source_id % 10 == PAGE_TYPE_EXT_SEARCH) {
if (!isset($_searchSourceData[$source_id])) {
echo "Search Source: {$source_id} Not Exists!\n";
continue;
}
$level_2_id = $_searchSourceData[$source_id]['level_2_id'];
}

$l2_access_key = "{$wh_id}_{$level_2_id}";

foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$order_product_num = isset($user_data['order_product_num']) ? $user_data['order_product_num'] : 0;
$order_fee = isset($user_data['order_fee']) ? $user_data['order_fee'] : 0.0;

$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;
$out_product_num = isset($user_data['out_product_num']) ? $user_data['out_product_num'] : 0;
$out_fee = isset($user_data['out_fee']) ? $user_data['out_fee'] : 0.0;

if (!isset($login_level_2_order_data[$l2_access_key])) {
$login_level_2_order_data[$l2_access_key] = array();
}

if (!isset($login_level_2_order_data[$l2_access_key][$user_type])) {
$login_level_2_order_data[$l2_access_key][$user_type] = array();
}

if (!isset($login_level_2_order_data[$l2_access_key][$user_type][$user_id])) {
$login_level_2_order_data[$l2_access_key][$user_type][$user_id] = array();

$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['order_num'] = 0;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['order_product_num'] = 0;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['order_fee'] = 0.0;

$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['out_num'] = 0;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['out_product_num'] = 0;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['out_fee'] = 0.0;
}

// 订单数据
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['order_num'] += $order_num;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['order_product_num'] += $order_product_num;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['order_fee'] += $order_fee;

// 出库订单数据
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['out_num'] += $out_num;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['out_product_num'] += $out_product_num;
$login_level_2_order_data[$l2_access_key][$user_type][$user_id]['out_fee'] += $out_fee;
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// Step 2.1: 获取已登录用户的数据
// 包括新老用户,未下过订单的用户算作新用户
$order_users_data = array();
$outstock_users_data = array();

// Get order data
foreach ($login_level_2_order_data as $l2_access_key => &$l2_access_data) {
// $l2_access_key 格式: 分站ID_二级来源ID
foreach ($l2_access_data as $user_type => &$users) {
$source_key = "{$l2_access_key}_{$user_type}";

foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($stat_level_2_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($users as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$stat_level_2_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$stat_level_2_result_data[$source_key]['out_user_num'] = $out_user_num;
}

// Step 2.2: 获取已登录用户的数据
// 包括新老用户,且包括未下过订单的用户
$order_users_data = array();
$outstock_users_data = array();

// Get Order data
foreach ($login_level_2_order_data as $l2_access_key => &$l2_access_data) {
// $l2_access_key 格式: 分站ID_二级来源ID
$user_type = USER_TYPE_ALL;
$source_key = "{$l2_access_key}_{$user_type}";

foreach ($l2_access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($stat_level_2_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$stat_level_2_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$stat_level_2_result_data[$source_key]['out_user_num'] = $out_user_num;
}

return true;
}

function _storeStatL2ResultData($s_date, &$stat_level_2_result_data)
{
GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

// 写入点击流DB
$mssql = false;
$db_name = 'ICSON_STATISTICS_CLICKFLOW';

$table_name = "t_aggregation_daily_ext_source_level_2_test2";

// $stat_level_2_result_data 格式: 分站ID_二级来源ID_用户类型
foreach ($stat_level_2_result_data as $source_key => &$source_data) {
$key_array = explode("_", $source_key);
if (!isset($key_array[2])) {
continue;
}

$wh_id = $key_array[0];
$level_2_id = $key_array[1];
$user_type = $key_array[2];

$level_1_id = $_statSourceData_Level_2[$level_2_id]['level_1_id'];

$order_num = isset($source_data['order_num']) ? $source_data['order_num'] : 0;
$order_product_num = isset($source_data['order_product_num']) ? $source_data['order_product_num'] : 0;
$order_fee = isset($source_data['order_fee']) ? $source_data['order_fee'] : 0.0;
$order_user_num = isset($source_data['order_user_num']) ? $source_data['order_user_num'] : 0;

$out_num = isset($source_data['out_num']) ? $source_data['out_num'] : 0;
$out_product_num = isset($source_data['out_product_num']) ? $source_data['out_product_num'] : 0;
$out_fee = isset($source_data['out_fee']) ? $source_data['out_fee'] : 0.0;
$out_user_num = isset($source_data['out_user_num']) ? $source_data['out_user_num'] : 0;

$condition = "s_date='{$s_date}' and warehouse_id={$wh_id} and level_1_id={$level_1_id} and level_2_id={$level_2_id} ";
$condition .= "and user_type={$user_type}";

$row = array(
'order_num_7day' => $order_num,
'order_product_num_7day' => $order_product_num,
'order_fee_7day' => $order_fee,
'order_user_num_7day' => $order_user_num,

'out_num_7day' => $out_num,
'out_product_num_7day' => $out_product_num,
'out_fee_7day' => $out_fee,
'out_user_num_7day' => $out_user_num,
);

$ret = _updateWithRetries($db_name, $table_name, $row, $condition, $mssql);
if (false === $ret) {
Logger::err("Update source channel stat data failed");

continue;
}
} // end of foreach ($stat_level_2_result_data as $source_key => &$source_data) { ...

return true;
}

/////////////////////////////////////////////////////////////////////////////////////////////////////////
// 获取一级数据
/////////////////////////////////////////////////////////////////////////////////////////////////////////

function _getStatL1ResultData(&$stat_level_1_result_data)
{
GLOBAL $_login_order_data;

GLOBAL $_sourceChannelData;
GLOBAL $_searchSourceData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

$login_level_1_order_data = array();
foreach ($_login_order_data as $access_key => &$access_data) {
// $access_key 格式: 分站ID_来源ID
$key_array = explode("_", $access_key);
if (!isset($key_array[1])) {
continue;
}

$wh_id = $key_array[0];
$source_id = $key_array[1];

$level_1_id = OTHER_LEVEL_1_ID;

// 直接访问处于一级
if (SOURCE_ID_DIRECT == $source_id) {
$level_1_id = DIRECT_LEVEL_1_ID;
}
// 外投推广数据
else if (SOURCE_ID_OTHER == $source_id) {
$level_1_id = OTHER_LEVEL_1_ID;
}
else if ($source_id % 10 == PAGE_TYPE_EXT_PROMOTION) {
if (!isset($_sourceChannelData[$source_id])) {
echo "Promotion Source: {$source_id} Not Exists!\n";
continue;
}
$level_1_id = $_sourceChannelData[$source_id]['level_1_id'];
}
else if ($source_id % 10 == PAGE_TYPE_EXT_SEARCH) {
if (!isset($_searchSourceData[$source_id])) {
echo "Search Source: {$source_id} Not Exists!\n";
continue;
}
$level_1_id = $_searchSourceData[$source_id]['level_1_id'];
}

$l1_access_key = "{$wh_id}_{$level_1_id}";

foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$order_product_num = isset($user_data['order_product_num']) ? $user_data['order_product_num'] : 0;
$order_fee = isset($user_data['order_fee']) ? $user_data['order_fee'] : 0.0;

$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;
$out_product_num = isset($user_data['out_product_num']) ? $user_data['out_product_num'] : 0;
$out_fee = isset($user_data['out_fee']) ? $user_data['out_fee'] : 0.0;

if (!isset($login_level_1_order_data[$l1_access_key])) {
$login_level_1_order_data[$l1_access_key] = array();
}

if (!isset($login_level_1_order_data[$l1_access_key][$user_type])) {
$login_level_1_order_data[$l1_access_key][$user_type] = array();
}

if (!isset($login_level_1_order_data[$l1_access_key][$user_type][$user_id])) {
$login_level_1_order_data[$l1_access_key][$user_type][$user_id] = array();

$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['order_num'] = 0;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['order_product_num'] = 0;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['order_fee'] = 0.0;

$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['out_num'] = 0;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['out_product_num'] = 0;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['out_fee'] = 0.0;
}

// 订单数据
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['order_num'] += $order_num;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['order_product_num'] += $order_product_num;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['order_fee'] += $order_fee;

// 出库订单数据
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['out_num'] += $out_num;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['out_product_num'] += $out_product_num;
$login_level_1_order_data[$l1_access_key][$user_type][$user_id]['out_fee'] += $out_fee;
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// Step 2.1: 获取已登录用户的数据
// 包括新老用户,未下过订单的用户算作新用户
$order_users_data = array();
$outstock_users_data = array();

// Get order data
foreach ($login_level_1_order_data as $l1_access_key => &$l1_access_data) {
// $l1_access_key 格式: 分站ID_一级来源ID
foreach ($l1_access_data as $user_type => &$users) {
$source_key = "{$l1_access_key}_{$user_type}";

foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($stat_level_1_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$stat_level_1_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$stat_level_1_result_data[$source_key]['out_user_num'] = $out_user_num;
}

// Step 2.2: 获取已登录用户的数据
// 包括新老用户,且包括未下过订单的用户
$order_users_data = array();
$outstock_users_data = array();

// Get order data
foreach ($login_level_1_order_data as $l1_access_key => &$l1_access_data) {
// $l1_access_key 格式: 分站ID_一级来源ID
$user_type = USER_TYPE_ALL;
$source_key = "{$l1_access_key}_{$user_type}";

foreach ($l1_access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($stat_level_1_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$stat_level_1_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$stat_level_1_result_data[$source_key]['out_user_num'] = $out_user_num;
}

return true;
}

function _storeStatL1ResultData($s_date, &$stat_level_1_result_data)
{
GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_3;

// 写入点击流DB
$mssql = false;
$db_name = 'ICSON_STATISTICS_CLICKFLOW';

$table_name = "t_aggregation_daily_ext_source_level_1_test2";

// $stat_level_1_result_data 格式: 分站ID_二级来源ID_用户类型
foreach ($stat_level_1_result_data as $source_key => &$source_data) {
$key_array = explode("_", $source_key);
if (!isset($key_array[2])) {
continue;
}

$wh_id = $key_array[0];
$level_1_id = $key_array[1];
$user_type = $key_array[2];

$order_num = isset($source_data['order_num']) ? $source_data['order_num'] : 0;
$order_product_num = isset($source_data['order_product_num']) ? $source_data['order_product_num'] : 0;
$order_fee = isset($source_data['order_fee']) ? $source_data['order_fee'] : 0.0;
$order_user_num = isset($source_data['order_user_num']) ? $source_data['order_user_num'] : 0;

$out_num = isset($source_data['out_num']) ? $source_data['out_num'] : 0;
$out_product_num = isset($source_data['out_product_num']) ? $source_data['out_product_num'] : 0;
$out_fee = isset($source_data['out_fee']) ? $source_data['out_fee'] : 0.0;
$out_user_num = isset($source_data['out_user_num']) ? $source_data['out_user_num'] : 0;

$condition = "s_date='{$s_date}' and warehouse_id={$wh_id} and level_1_id={$level_1_id} ";
$condition .= "and user_type={$user_type}";

$row = array(
'order_num_7day' => $order_num,
'order_product_num_7day' => $order_product_num,
'order_fee_7day' => $order_fee,
'order_user_num_7day' => $order_user_num,

'out_num_7day' => $out_num,
'out_product_num_7day' => $out_product_num,
'out_fee_7day' => $out_fee,
'out_user_num_7day' => $out_user_num,
);

$ret = _updateWithRetries($db_name, $table_name, $row, $condition, $mssql);
if (false === $ret) {
Logger::err("Update source channel stat data failed");

continue;
}
} // end of foreach ($stat_level_1_result_data as $source_key => &$source_data) { ...

return true;
}

///////////////////////////////////////////////////////////////////////////////////////
// 渠道数据 一级、 二级 TAG 汇总
///////////////////////////////////////////////////////////////////////////////////////

function _getAggL2ChannelResultData(&$agg_channel_result_data)
{
GLOBAL $_login_order_data;

GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

GLOBAL $_tag_Level_1;
GLOBAL $_tag_Level_2;

$login_agg_l2_order_data = array();
foreach ($_login_order_data as $access_key => &$access_data) {
// $access_key 格式: 分站ID_来源ID
$key_array = explode("_", $access_key);
if (!isset($key_array[1])) {
continue;
}

$wh_id = $key_array[0];
$source_id = $key_array[1];
// 只获取外投推广数据
if ($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) {
continue;
}

if (!isset($_sourceChannelData[$source_id])) {
continue;
}
$tag_level_1_id = $_sourceChannelData[$source_id]['tag_level_1_id'];
$tag_level_2_id = $_sourceChannelData[$source_id]['tag_level_2_id'];

$agg_l2_access_key = "{$wh_id}_{$tag_level_1_id}_{$tag_level_2_id}";

foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$order_product_num = isset($user_data['order_product_num']) ? $user_data['order_product_num'] : 0;
$order_fee = isset($user_data['order_fee']) ? $user_data['order_fee'] : 0.0;

$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;
$out_product_num = isset($user_data['out_product_num']) ? $user_data['out_product_num'] : 0;
$out_fee = isset($user_data['out_fee']) ? $user_data['out_fee'] : 0.0;

if (!isset($login_agg_l2_order_data[$agg_l2_access_key])) {
$login_agg_l2_order_data[$agg_l2_access_key] = array();
}

if (!isset($login_agg_l2_order_data[$agg_l2_access_key][$user_type])) {
$login_agg_l2_order_data[$agg_l2_access_key][$user_type] = array();
}

if (!isset($login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id])) {
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id] = array();

$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['order_num'] = 0;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['order_product_num'] = 0;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['order_fee'] = 0.0;

$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['out_num'] = 0;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['out_product_num'] = 0;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['out_fee'] = 0.0;
}

// 订单数据
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['order_num'] += $order_num;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['order_product_num'] += $order_product_num;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['order_fee'] += $order_fee;

// 出库订单数据
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['out_num'] += $out_num;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['out_product_num'] += $out_product_num;
$login_agg_l2_order_data[$agg_l2_access_key][$user_type][$user_id]['out_fee'] += $out_fee;
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...


// Step 2.1: 获取已登录用户的数据
// 包括新老用户,未下过订单的用户算作新用户
$order_users_data = array();
$outstock_users_data = array();

foreach ($login_agg_l2_order_data as $agg_l2_access_key => &$agg_l2_access_data) {
// $agg_l2_access_key 格式: 分站ID_一级TAGID_二级TAGID

foreach ($agg_l2_access_data as $user_type => &$users) {
$source_key = "{$agg_l2_access_key}_{$user_type}";

foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($agg_channel_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$agg_channel_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$agg_channel_result_data[$source_key]['out_user_num'] = $out_user_num;
}

// Step 2.2: 获取已登录用户的数据
// 包括新老用户,且包括未下过订单的用户
$order_users_data = array();
$outstock_users_data = array();

foreach ($login_agg_l2_order_data as $agg_l2_access_key => &$agg_l2_access_data) {
// $agg_l2_access_key 格式: 分站ID_一级TAGID_二级TAGID

$user_type = USER_TYPE_ALL;
$source_key = "{$agg_l2_access_key}_{$user_type}";

foreach ($agg_l2_access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($agg_channel_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$agg_channel_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$agg_channel_result_data[$source_key]['out_user_num'] = $out_user_num;
}

$order_users_data = null;
$outstock_users_data = null;

return true;
}

function _getAggL1ChannelResultData(&$agg_channel_result_data)
{
GLOBAL $_login_order_data;

GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

GLOBAL $_tag_Level_1;
GLOBAL $_tag_Level_2;

$login_agg_l1_order_data = array();
foreach ($_login_order_data as $access_key => &$access_data) {
// $access_key 格式: 分站ID_来源ID
$key_array = explode("_", $access_key);
if (!isset($key_array[1])) {
continue;
}

$wh_id = $key_array[0];
$source_id = $key_array[1];
// 只获取外投推广数据
if ($source_id % 10 != PAGE_TYPE_EXT_PROMOTION) {
continue;
}

if (!isset($_sourceChannelData[$source_id])) {
continue;
}
$tag_level_1_id = $_sourceChannelData[$source_id]['tag_level_1_id'];
$tag_level_2_id = CHANNEL_ALL_SOURCE_ID;

$agg_l1_access_key = "{$wh_id}_{$tag_level_1_id}_{$tag_level_2_id}";

foreach ($access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$order_product_num = isset($user_data['order_product_num']) ? $user_data['order_product_num'] : 0;
$order_fee = isset($user_data['order_fee']) ? $user_data['order_fee'] : 0.0;

$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;
$out_product_num = isset($user_data['out_product_num']) ? $user_data['out_product_num'] : 0;
$out_fee = isset($user_data['out_fee']) ? $user_data['out_fee'] : 0.0;

if (!isset($login_agg_l1_order_data[$agg_l1_access_key])) {
$login_agg_l1_order_data[$agg_l1_access_key] = array();
}

if (!isset($login_agg_l1_order_data[$agg_l1_access_key][$user_type])) {
$login_agg_l1_order_data[$agg_l1_access_key][$user_type] = array();
}

if (!isset($login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id])) {
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id] = array();

$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['order_num'] = 0;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['order_product_num'] = 0;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['order_fee'] = 0.0;

$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['out_num'] = 0;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['out_product_num'] = 0;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['out_fee'] = 0.0;
}

// 订单数据
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['order_num'] += $order_num;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['order_product_num'] += $order_product_num;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['order_fee'] += $order_fee;

// 出库订单数据
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['out_num'] += $out_num;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['out_product_num'] += $out_product_num;
$login_agg_l1_order_data[$agg_l1_access_key][$user_type][$user_id]['out_fee'] += $out_fee;
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// Step 2.1: 获取已登录用户的数据
// 包括新老用户,未下过订单的用户算作新用户
$order_users_data = array();
$outstock_users_data = array();

// Get order data
foreach ($login_agg_l1_order_data as $agg_l1_access_key => &$agg_l1_access_data) {
// $agg_l1_access_key 格式: 分站ID_一级TAGID_二级TAGID

foreach ($agg_l1_access_data as $user_type => &$users) {
$source_key = "{$agg_l1_access_key}_{$user_type}";

foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($agg_channel_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}
} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$agg_channel_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$agg_channel_result_data[$source_key]['out_user_num'] = $out_user_num;
}

// Step 2.2: 获取已登录用户的数据
// 包括新老用户,且包括未下过订单的用户
$order_users_data = array();
$outstock_users_data = array();

foreach ($login_agg_l1_order_data as $agg_l1_access_key => &$agg_l1_access_data) {
// $agg_l1_access_key 格式: 分站ID_一级TAGID_二级TAGID

$user_type = USER_TYPE_ALL;
$source_key = "{$agg_l1_access_key}_{$user_type}";

foreach ($agg_l1_access_data as $user_type => &$users) {
foreach ($users as $user_id => &$user_data) {
_generalUpdateResultPVOrderData($agg_channel_result_data, $source_key, $user_data);

$order_num = isset($user_data['order_num']) ? $user_data['order_num'] : 0;
$out_num = isset($user_data['out_num']) ? $user_data['out_num'] : 0;

// 统计下单人数
if ($order_num > 0) {
if (!isset($order_users_data[$source_key])) {
$order_users_data[$source_key] = array();
}
$order_users_data[$source_key][$user_id] = 0;
}

// 统计出库人数
if ($out_num > 0) {
if (!isset($outstock_users_data[$source_key])) {
$outstock_users_data[$source_key] = array();
}
$outstock_users_data[$source_key][$user_id] = 0;
}

} // end of foreach ($access_data as $user_id => &$user_data) { ...
}
} // end of foreach ($_login_access_data as $access_key => &$access_data) { ...

// 统计下单,出库人数
foreach ($order_users_data as $source_key => &$source_data) {
$order_user_num = count($source_data);

$agg_channel_result_data[$source_key]['order_user_num'] = $order_user_num;
}

foreach ($outstock_users_data as $source_key => &$source_data) {
$out_user_num = count($source_data);

$agg_channel_result_data[$source_key]['out_user_num'] = $out_user_num;
}

$order_users_data = null;
$outstock_users_data = null;

return true;
}


function _storeAggChannelResultData($s_date, &$agg_channel_result_data)
{
GLOBAL $_sourceChannelData;

GLOBAL $_statSourceData_Level_1;
GLOBAL $_statSourceData_Level_2;
GLOBAL $_statSourceData_Level_3;

GLOBAL $_tag_Level_1;
GLOBAL $_tag_Level_2;


// 写入点击流DB
$mssql = false;
$db_name = 'ICSON_STATISTICS_CLICKFLOW';

$table_name = "t_aggregation_daily_ext_source_channel_stat_test2";

// $agg_channel_result_data 格式: 分站ID_一级TAGID_二级TAGID_用户类型
foreach ($agg_channel_result_data as $source_key => &$source_data) {
$key_array = explode("_", $source_key);
if (!isset($key_array[3])) {
continue;
}

$wh_id = $key_array[0];
$tag_level_1_id = $key_array[1];
$tag_level_2_id = $key_array[2];
$user_type = $key_array[3];

$order_num = isset($source_data['order_num']) ? $source_data['order_num'] : 0;
$order_product_num = isset($source_data['order_product_num']) ? $source_data['order_product_num'] : 0;
$order_fee = isset($source_data['order_fee']) ? $source_data['order_fee'] : 0.0;
$order_user_num = isset($source_data['order_user_num']) ? $source_data['order_user_num'] : 0;

$out_num = isset($source_data['out_num']) ? $source_data['out_num'] : 0;
$out_product_num = isset($source_data['out_product_num']) ? $source_data['out_product_num'] : 0;
$out_fee = isset($source_data['out_fee']) ? $source_data['out_fee'] : 0.0;
$out_user_num = isset($source_data['out_user_num']) ? $source_data['out_user_num'] : 0;

$condition = "s_date='{$s_date}' and warehouse_id={$wh_id} and level_1_id={$tag_level_1_id} and level_2_id={$tag_level_2_id} ";
$condition .= "and user_type={$user_type}";

$row = array(
'order_num_7day' => $order_num,
'order_product_num_7day' => $order_product_num,
'order_fee_7day' => $order_fee,
'order_user_num_7day' => $order_user_num,

'out_num_7day' => $out_num,
'out_product_num_7day' => $out_product_num,
'out_fee_7day' => $out_fee,
'out_user_num_7day' => $out_user_num,
);

$ret = _updateWithRetries($db_name, $table_name, $row, $condition, $mssql);
if (false === $ret) {
Logger::err("Update source channel stat data failed");

continue;
}
} // end of foreach ($agg_channel_result_data as $source_key => &$source_data) { ...

return true;
}


function _runSingleDay($s_date)
{
GLOBAL $_login_order_data;

$_login_order_data = array();

$date_str = date("Ymd", strtotime($s_date));
$daily_log_filename = CLICKFLOW_DATA_DIR . "row_data_{$date_str}";

echo "Ext Source Order Statistic For: [{$s_date}] Started at: ", date("Y-m-d H:i:s"), ".\n";

// Step 1: 获取订单数据
_getSourceOrdersData($s_date);

echo "Step 1: Get Orders Data Complete: ", date("Y-m-d H:i:s"), ".\n";

// Step 2: Get Channel Source Result Data
$channel_source_result_data = array();
_getChannelSourceResultData($channel_source_result_data);
_storeChannelSourceResultData($s_date, $channel_source_result_data);

// 不再使用,释放资源
$channel_source_result_data = null;

echo "Step 2: Get and Store Channel Source Result Data Complete: ", date("Y-m-d H:i:s"), ".\n";

// Step 3: Get Stat Level 3 Result Data
// 只有渠道推广才有三级统计数据
$stat_level_3_result_data = array();
_getStatL3ResultData($stat_level_3_result_data);
_storeStatL3ResultData($s_date, $stat_level_3_result_data);

$stat_level_3_result_data = null;

echo "Step 3: Get Stat Level 3 Result Data Complete: ", date("Y-m-d H:i:s"), ".\n";

// Step 4: Get Stat Level 2 Result Data
$stat_level_2_result_data = array();
_getStatL2ResultData($stat_level_2_result_data);
_storeStatL2ResultData($s_date, $stat_level_2_result_data);

$stat_level_2_result_data = null;

echo "Step 4: Get Stat Level 2 Result Data Complete: ", date("Y-m-d H:i:s"), ".\n";

// Step 5: Get Stat Level 1 Result Data
$stat_level_1_result_data = array();
_getStatL1ResultData($stat_level_1_result_data);
_storeStatL1ResultData($s_date, $stat_level_1_result_data);

$stat_level_1_result_data = null;

echo "Step 5: Get Stat Level 1 Result Data Complete: ", date("Y-m-d H:i:s"), ".\n";


// Step 6: Channel Level 1 and Level 2 Aggregation Result Data
$agg_channel_result_data = array();
_getAggL2ChannelResultData($agg_channel_result_data);
_getAggL1ChannelResultData($agg_channel_result_data);
_storeAggChannelResultData($s_date, $agg_channel_result_data);

$agg_channel_result_data = null;

echo "Step 6: Channel Level 1 and Level 2 Aggregation Result Data Complete: ", date("Y-m-d H:i:s"), ".\n";

return true;
}

function run($s_date_from, $s_date_to)
{
// 获取TAG系统数据
_getSourceChannelData();
_getStatSourceData_Level_X();

echo "Step 0: Get Source Channle and Stat Data Complete: ", date("Y-m-d H:i:s"), ".\n\n";

for ($date_iter = $s_date_from; $date_iter <= $s_date_to;
$date_iter = date('Y-m-d', strtotime('+1 day', strtotime($date_iter)))) {
echo "================================================================\n";

_runSingleDay($date_iter);

echo "================================================================\n";
}

return true;
}

$process_start = date("Y-m-d H:i:s");

$_s_date_from = isset($argv[1]) ? $argv[1] : date("Y-m-d", strtotime("-1 day"));
$_s_date_to = isset($argv[2]) ? $argv[2] : $_s_date_from;

echo "extSourceStat_7Day_Orders Start at: ", date("Y-m-d H:i:s"), " For: ", "[{$_s_date_from} ~ {$_s_date_to}]", ".\n";

run($_s_date_from, $_s_date_to);

$process_end = date("Y-m-d H:i:s");

echo "extSourceStat_7Day_Orders Done, For: [{$_s_date_from} - {$_s_date_to}], Done.[{$process_start} ~ {$process_end}].\n";

 

  

posted on 2014-08-27 19:31  阮佳佳  阅读(247)  评论(0编辑  收藏  举报

导航