Batch
[ class tree: Batch ] [ index: Batch ] [ all elements ]

Source for file SC_Batch_Daily.php

Documentation is available at SC_Batch_Daily.php

  1. <?php
  2. /*
  3.  * This file is part of EC-CUBE
  4.  *
  5.  * Copyright(c) 2000-2010 LOCKON CO.,LTD. All Rights Reserved.
  6.  *
  7.  * http://www.lockon.co.jp/
  8.  *
  9.  * This program is free software; you can redistribute it and/or
  10.  * modify it under the terms of the GNU General Public License
  11.  * as published by the Free Software Foundation; either version 2
  12.  * of the License, or (at your option) any later version.
  13.  *
  14.  * This program is distributed in the hope that it will be useful,
  15.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  17.  * GNU General Public License for more details.
  18.  *
  19.  * You should have received a copy of the GNU General Public License
  20.  * along with this program; if not, write to the Free Software
  21.  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
  22.  */
  23.  
  24. // {{{ requires
  25. require_once(CLASS_PATH "batch/SC_Batch.php");
  26.  
  27. /**
  28.  * 日次バッチクラス.
  29.  *
  30.  * XXX Singleton にするべき...
  31.  *
  32.  * @package Batch
  33.  * @author LOCKON CO.,LTD.
  34.  * @version $Id$
  35.  */
  36. class SC_Batch_Daily extends SC_Batch {
  37.  
  38.  
  39.     /**
  40.      * コンストラクタ.
  41.      *
  42.      * @param array $argv コマンドライン用引数.
  43.      *                     指定しない場合は, 内部関数が実行されない.
  44.      */
  45.     function SC_Batch_Daily($argv ""{
  46.  
  47.         if (!empty($argv)) {
  48.             $this->execute($argv);
  49.         }
  50.     }
  51.  
  52.     /**
  53.      * バッチ処理を実行する.
  54.      *
  55.      * @param mixed $argv コマンドライン引数
  56.      * @return void 
  57.      */
  58.     function execute($argv ""{
  59.         $term 0;
  60.         $start 1;    // 集計期間は、$start~$termの間となる。通常前日分から。
  61.         $command false;
  62.  
  63.         // 集計対象期間の取得(指定日分さかのぼる)
  64.         if (SC_Utils_Ex::sfIsInt($argv[1]&& $argv[1<= 365{
  65.             $term $argv[1];
  66.             $command true;
  67.         }
  68.  
  69.         // 集計開始日
  70.         if (SC_Utils_Ex::sfIsInt($argv[2]&& $argv[2<= 365{
  71.             $start $argv[2];
  72.             $command true;
  73.         }
  74.  
  75.         if($term 0{
  76.             // 集計の開始
  77.             $this->lfStartDailyTotal($term$start$command);
  78.         }
  79.     }
  80.  
  81.     // 集計の開始
  82.     function lfStartDailyTotal($term$start$command false{
  83.  
  84.         $now_time time();
  85.  
  86.         // グラフ画像の削除
  87.         $path GRAPH_DIR "*.png";
  88.         system ("rm -rf $path");
  89.  
  90.         // 削除された受注データの受注詳細情報の削除
  91.         $objQuery new SC_Query();
  92.         $where "order_id IN (SELECT order_id FROM dtb_order WHERE del_flg = 1)";
  93.         $objQuery->delete("dtb_order_detail"$where);
  94.  
  95.         // 最後に更新された日付を取得
  96.         $ret $objQuery->max("dtb_bat_order_daily""create_date");
  97.         list($batch_lastsplit("\."$ret);
  98.         $pass $now_time strtotime($batch_last);
  99.  
  100.         // 最後のバッチ実行からLOAD_BATCH_PASS秒経過していないと実行しない。
  101.         if($pass LOAD_BATCH_PASS{
  102.             GC_Utils_Ex::gfPrintLog("LAST BATCH " $arrRet[0]['create_date'" > " $batch_pass " -> EXIT BATCH $batch_date");
  103.             return;
  104.         }
  105.  
  106.         // 集計
  107.         for ($i $start$i $term$i++{
  108.             // 基本時間から$i日分さかのぼる
  109.             $tmp_time $now_time ($i 24 3600);
  110.  
  111.             $batch_date date("Y/m/d"$tmp_time);
  112.             GC_Utils_Ex::gfPrintLog("LOADING BATCH $batch_date");
  113.  
  114.             $this->lfBatOrderDaily($tmp_time);
  115.             $this->lfBatOrderDailyHour($tmp_time);
  116.             $this->lfBatOrderAge($tmp_time);
  117.  
  118.             // タイムアウトを防ぐ
  119.             SC_Utils_Ex::sfFlush();
  120.         }
  121.     }
  122.  
  123.     // リアルタイムで集計を実施する。集計が終了しているレコードは実施しない。
  124.     /*
  125.      $sdate:YYYY-MM-DD hh:mm:ss形式の日付
  126.      $edate:YYYY-MM-DD hh:mm:ss形式の日付
  127.     */
  128.     function lfRealTimeDailyTotal($sdate$edate{
  129.         $pass strtotime($edatestrtotime($sdate);
  130.         $loop intval($pass 86400);
  131.  
  132.         for($i 0$i <= $loop$i++{
  133.             $tmp_time strtotime($sdate($i 86400);
  134.             $batch_date date("Y/m/d H:i:s"$tmp_time);
  135.             $objQuery new SC_Query();
  136.             $arrRet $objQuery->select("order_date, create_date""dtb_bat_order_daily""order_date = ?"array($batch_date));
  137.             // すでにバッチ処理が終了しているかチェックする。
  138.             $count count($arrRet);
  139.             if$count {
  140.                 list($create_datesplit("\."$arrRet[0]['create_date']);
  141.                 list($order_datesplit("\."$arrRet[0]['order_date']);
  142.                 $create_time strtotime($create_date);
  143.                 $order_time strtotime($order_date);
  144.                 // オーダー開始日より一日以上後に集計されている場合は集計しなおさない
  145.                 if($order_time 86400 $create_time || $tmp_time time()) {
  146.                     GC_Utils_Ex::gfPrintLog("EXIT BATCH $batch_date $tmp_time" " time());
  147.                     continue;
  148.                 }
  149.             }
  150.             GC_Utils_Ex::gfPrintLog("LOADING BATCH $batch_date");
  151.             $this->lfBatOrderDaily($tmp_time);
  152.             $this->lfBatOrderDailyHour($tmp_time);
  153.             $this->lfBatOrderAge($tmp_time);
  154.         }
  155.     }
  156.  
  157.     // バッチ集計用のSQL文を取得する。
  158.     function lfGetOrderDailySQL($start$end{
  159.         $from " FROM dtb_order AS T1 LEFT JOIN dtb_customer AS T2 USING ( customer_id ) ";
  160.         $where " WHERE T1.del_flg = 0 AND T1.status <> " ORDER_CANCEL " AND T1.create_date BETWEEN '$start' AND '$end";
  161.  
  162.         /*    mysqlでも問題ないように修正
  163.          $sql = "SELECT ";
  164.          $sql.= "COUNT(*) AS total_order, ";
  165.          $sql.= "SUM((SELECT COUNT(*) WHERE customer_id = 0)) AS nonmember, ";
  166.          $sql.= "SUM((SELECT COUNT(*) WHERE customer_id <> 0 GROUP BY customer_id)) AS member, ";
  167.          $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1)) AS men, ";
  168.          $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2)) AS women, ";
  169.          $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1 AND customer_id <> 0)) AS men_member, ";
  170.          $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1 AND customer_id = 0)) AS men_nonmember, ";
  171.          $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2 AND customer_id <> 0)) AS women_member, ";
  172.          $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2 AND customer_id = 0)) AS women_nonmember, ";
  173.          $sql.= "SUM(total) AS total, ";
  174.          $sql.= "int8(AVG(total)) AS total_average ";
  175.          $sql.= $from;
  176.          $sql.= $where;        // 受注作成日で検索する
  177.         */
  178.         $sql "SELECT ";
  179.         $sql.= "COUNT(*) AS total_order, ";
  180.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.customer_id = 0) AS nonmember ) AS nonmember, ";
  181.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.customer_id <> 0) AS member ) AS member, ";
  182.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.order_sex = 1) AS men ) AS men, ";
  183.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.order_sex = 2) AS women ) AS women, ";
  184.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.order_sex = 1 AND T2.customer_id <> 0) AS men_member ) AS men_member, ";
  185.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.order_sex = 1 AND T1.customer_id = 0) AS men_nonmember ) AS men_nonmember, ";
  186.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.order_sex = 2 AND T2.customer_id <> 0) AS women_member ) AS women_member, ";
  187.         $sql.= "(SELECT sum(cnt) FROM (SELECT COUNT(*) AS cnt $from $where AND T1.order_sex = 2 AND T1.customer_id = 0) AS women_nonmember ) AS women_nonmember, ";
  188.         $sql.= "SUM(total) AS total, ";
  189.         $sql.= "(AVG(total)) AS total_average ";
  190.         $sql.= $from;
  191.         $sql.= $where;        // 受注作成日で検索する
  192.  
  193.         return $sql;
  194.     }
  195.  
  196.     // 売上げ集計バッチ処理(日別)
  197.     function lfBatOrderDaily($time{
  198.         $masterData new SC_DB_MasterData_Ex();
  199.         $arrWDAY $masterData->getMasterData("mtb_wday");
  200.         // 集計対象日を取得する
  201.         $date date("Y-m-d"$time);
  202.  
  203.         $start $date " 00:00:00";
  204.         $end $date " 23:59:59";
  205.  
  206.         $sql $this->lfGetOrderDailySQL($start,$end);
  207.  
  208.         $objQuery new SC_Query();
  209.         $arrRet $objQuery->getAll($sql);
  210.  
  211.         $sqlval $arrRet[0];
  212.  
  213.         // 空文字を"0"に変換
  214.         foreach($sqlval as $key => $val{
  215.             if ($val == ""{
  216.                 $sqlval[$key"0";
  217.             }
  218.         }
  219.  
  220.         $sqlval['create_date''now()';
  221.         $sqlval['order_date'$start;
  222.         $sqlval['year'date("Y"$time);
  223.         $sqlval['month'date("m"$time);
  224.         $sqlval['day'date("d"$time);
  225.         $sqlval['wday'date("w"$time);
  226.         $sqlval['key_day'sprintf("%02d/%02d/%02d"substr($sqlval['year'],2)$sqlval['month']$sqlval['day']);
  227.         $sqlval['key_month'sprintf("%02d/%02d"substr($sqlval['year'],2)$sqlval['month']);
  228.         $sqlval['key_year'sprintf("%d"$sqlval['year']);
  229.         $sqlval['key_wday'sprintf("%s"$arrWDAY[$sqlval['wday']]);
  230.  
  231.         $objQuery->delete("dtb_bat_order_daily""order_date = ?"array($start));
  232.         $objQuery->insert("dtb_bat_order_daily"$sqlval);
  233.     }
  234.  
  235.     // 売上げ集計バッチ処理(時間別)
  236.     function lfBatOrderDailyHour($time{
  237.  
  238.         // 集計対象日を取得する
  239.         $date date("Y-m-d"$time);
  240.         $objQuery new SC_Query();
  241.  
  242.         $start $date " 00:00:00";
  243.         $objQuery->delete("dtb_bat_order_daily_hour""order_date = ?"array($start));
  244.  
  245.         // 1時間毎に集計する。
  246.         for($i 0$i 24$i++{
  247.             $sdate sprintf("%s %02d:00:00"$date$i);
  248.             $edate sprintf("%s %02d:59:59"$date$i);
  249.             $sql $this->lfGetOrderDailySQL($sdate$edate);
  250.             $arrRet $objQuery->getAll($sql);
  251.             $sqlval $arrRet[0];
  252.             // 空文字を"0"に変換
  253.             foreach($sqlval as $key => $val{
  254.                 if ($val == ""{
  255.                     $sqlval[$key"0";
  256.                 }
  257.             }
  258.             $sqlval['create_date'"now()";
  259.             $sqlval['order_date'$start;
  260.             $sqlval['hour'"$i";
  261.             $objQuery->insert("dtb_bat_order_daily_hour"$sqlval);
  262.         }
  263.     }
  264.  
  265.     // 売上げ集計バッチ処理(年齢別)
  266.     function lfBatOrderAge($time{
  267.  
  268.         $age_loop intval(BAT_ORDER_AGE 10);
  269.  
  270.         // 年齢の範囲を指定してデータ抽出
  271.         $sql "SELECT COUNT(*) AS order_count, SUM(total) AS total, (AVG(total)) AS total_average ";
  272.         $sql.= "FROM dtb_order ";
  273.  
  274.         // 集計対象日を取得する
  275.         $date date("Y-m-d"$time);
  276.  
  277.         $start $date " 00:00:00";
  278.         $end $date " 23:59:59";
  279.  
  280.         $objQuery new SC_Query();
  281.         $objQuery->delete("dtb_bat_order_daily_age""order_date = ?"array($start));
  282.  
  283.         /* 会員集計 */
  284.  
  285.         $base_where "WHERE (create_date BETWEEN ? AND ?) AND customer_id <> 0 AND del_flg = 0 AND status <> " ORDER_CANCEL;
  286.  
  287.         $end_date date("Y/m/d"time());
  288.         $start_date date("Y/m/d",strtotime("-10 year" ,strtotime($end_date)));
  289.         $end_date date("Y/m/d",strtotime("1 day" ,strtotime($end_date)));
  290.         // 年齢毎に集計する。
  291.         for($i 0$i <= $age_loop$i++{
  292.             $where $base_where " AND order_birth >= cast('$start_date' as date)";
  293.             $start_age $i 10;
  294.             if($i $age_loop{
  295.                 $end_age $start_age+9;
  296.                 $where $where " AND order_birth < cast('$end_date' as date)";
  297.             }else{
  298.                 $where $base_where " AND order_birth < cast('$end_date' as date)";
  299.                 $end_age 999;
  300.             }
  301.             $this->lfBatOrderAgeSub($sql $where$start$end$start_age$end_age1);
  302.             $end_date date("Y/m/d",strtotime("1 day" ,strtotime($start_date)));
  303.             $start_date date("Y/m/d",strtotime("-10 year",strtotime($start_date)));
  304.         }
  305.  
  306.         // 誕生日入力なし
  307.         $where $base_where " AND order_birth IS NULL ";
  308.         $this->lfBatOrderAgeSub($sql $where$start$endNULLNULL1);
  309.  
  310.         /* 非会員集計 */
  311.  
  312.         $base_where "WHERE (create_date BETWEEN ? AND ?) AND customer_id = 0 AND del_flg = 0 AND status <> " ORDER_CANCEL;
  313.         $where $base_where " AND (to_number(to_char(age(current_timestamp, order_birth), 'YYY'), 999) BETWEEN ? AND ?) ";
  314.  
  315.         $end_date date("Y/m/d"time());
  316.         $start_date date("Y/m/d",strtotime("-10 year" ,strtotime($end_date)));
  317.         $end_date date("Y/m/d",strtotime("1 day" ,strtotime($end_date)));
  318.         // 年齢毎に集計する。
  319.         for($i 0$i <= $age_loop$i++{
  320.             $where $base_where " AND order_birth >= cast('$start_date' as date)";
  321.             $start_age $i 10;
  322.             if($i $age_loop{
  323.                 $end_age $start_age+9;
  324.                 $where $where " AND order_birth < cast('$end_date' as date)";
  325.             }else{
  326.                 $where $base_where " AND order_birth < cast('$end_date' as date)";
  327.                 $end_age 999;
  328.             }
  329.             $this->lfBatOrderAgeSub($sql $where$start$end$start_age$end_age0);
  330.             $end_date date("Y/m/d",strtotime("1 day" ,strtotime($start_date)));
  331.             $start_date date("Y/m/d",strtotime("-10 year",strtotime($start_date)));
  332.         }
  333.  
  334.         // 誕生日入力なし
  335.         $where $base_where " AND order_birth IS NULL AND del_flg = 0";
  336.         $this->lfBatOrderAgeSub($sql $where$start$endNULLNULL0);
  337.     }
  338.  
  339.     // 売上げ集計バッチ処理(年齢別) 登録部分
  340.     function lfBatOrderAgeSub($sql$start$end$start_age$end_age$member{
  341.         $objQuery new SC_Query();
  342.  
  343.         $arrRet $objQuery->getAll($sqlarray($start$end));
  344.         $sqlval $arrRet[0];
  345.  
  346.         // 空文字を"0"に変換
  347.         foreach($sqlval as $key => $val{
  348.             if ($val == ""{
  349.                 $sqlval[$key"0";
  350.             }
  351.         }
  352.  
  353.         $sqlval['create_date'"now()";
  354.         $sqlval['order_date'$start;
  355.         $sqlval['start_age'"$start_age";
  356.         $sqlval['end_age'"$end_age";
  357.         $sqlval['member'"$member";
  358.  
  359.         $objQuery->insert("dtb_bat_order_daily_age"$sqlval);
  360.     }
  361.  
  362.     // 文字列にSingleQuotationを付与する
  363.     function lfSingleQuot($value){
  364.         $ret "";
  365.         if (DB_TYPE == "mysql"{
  366.             $ret $value;
  367.         }else{
  368.             $ret "'" $value "'";
  369.         }
  370.         return $ret;
  371.     }
  372. }
  373. ?>

Documentation generated on Fri, 24 Feb 2012 13:59:57 +0900 by Seasoft