source: temp/trunk/html/admin/batch/daily.php @ 3466

Revision 3466, 7.9 KB checked in by naka, 20 years ago (diff)

* empty log message *

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1<?php
2
3$daily_php_dir = realpath(dirname( __FILE__));
4require_once($daily_php_dir . "/../require.php");
5
6$term = 0;
7$start = 1; // ½¸·×´ü´Ö¤Ï¡¢$start¢·$term¤Î´Ö¤È¤Ê¤ë¡£Ä̾ïÁ°Æüʬ¤«¤é¡£
8$command = false;
9
10// ½¸·×Âоݴü´Ö¤Î¼èÆÀ¡Ê»ØÄêÆüʬ¤µ¤«¤Î¤Ü¤ë)
11if (sfIsInt($argv[1]) && $argv[1] <= 365) {
12    $term = $argv[1];
13    $command = true;
14}
15
16// ½¸·×³«»ÏÆü
17if (sfIsInt($argv[2]) && $argv[2] <= 365) {
18    $start = $argv[2];
19    $command = true;
20}
21
22if($term > 0) {
23    // ½¸·×¤Î³«»Ï
24    lfStartDailyTotal($term, $start, $command);
25}
26
27// ½¸·×¤Î³«»Ï
28function lfStartDailyTotal($term, $start, $command = false) {
29       
30    $now_time = time();
31       
32    // ¥°¥é¥Õ²èÁü¤Îºï½ü
33    $path = GRAPH_DIR . "*.png";
34    system ("rm -rf $path");
35   
36    // ºï½ü¤µ¤ì¤¿¼õÃí¥Ç¡¼¥¿¤Î¼õÃí¾ÜºÙ¾ðÊó¤Îºï½ü
37    $objQuery = new SC_Query();
38    $where = "order_id IN (SELECT order_id FROM dtb_order WHERE delete = 1)";
39    $objQuery->delete("dtb_order_detail", $where);
40   
41    // ºÇ¸å¤Ë¹¹¿·¤µ¤ì¤¿ÆüÉÕ¤ò¼èÆÀ
42    $ret = $objQuery->max("dtb_bat_order_daily", "create_date");
43    list($batch_last) = split("\.", $ret);
44    $pass = $now_time - strtotime($batch_last);
45       
46    // ºÇ¸å¤Î¥Ð¥Ã¥Á¼Â¹Ô¤«¤éLOAD_BATCH_PASSÉ÷вᤷ¤Æ¤¤¤Ê¤¤¤È¼Â¹Ô¤·¤Ê¤¤¡£
47    if($pass < LOAD_BATCH_PASS) {
48        gfPrintLog("LAST BATCH " . $arrRet[0]['create_date'] . " > " . $batch_pass . " -> EXIT BATCH $batch_date");
49        return;
50    }
51       
52    // ½¸·×
53    for ($i = $start; $i < $term; $i++) {
54        // ´ðËÜ»þ´Ö¤«¤é$iÆüʬ¤µ¤«¤Î¤Ü¤ë
55        $tmp_time = $now_time - ($i * 24 * 3600);
56               
57        $batch_date = date("Y/m/d", $tmp_time);
58        gfPrintLog("LOADING BATCH $batch_date");
59                   
60        lfBatOrderDaily($tmp_time);
61        lfBatOrderDailyHour($tmp_time);
62        lfBatOrderAge($tmp_time);
63    }
64}
65
66// ¥ê¥¢¥ë¥¿¥¤¥à¤Ç½¸·×¤ò¼Â»Ü¤¹¤ë¡£½¸·×¤¬½ªÎ»¤·¤Æ¤¤¤ë¥ì¥³¡¼¥É¤Ï¼Â»Ü¤·¤Ê¤¤¡£
67/*
68    $sdate:YYYY-MM-DD hh:mm:ss·Á¼°¤ÎÆüÉÕ
69    $edate:YYYY-MM-DD hh:mm:ss·Á¼°¤ÎÆüÉÕ
70*/
71function lfRealTimeDailyTotal($sdate, $edate) {
72    $pass = strtotime($edate) - strtotime($sdate);
73    $loop = intval($pass / 86400);
74   
75    for($i = 0; $i <= $loop; $i++) {
76        $tmp_time = strtotime($sdate) + ($i * 86400);
77        $batch_date = date("Y/m/d H:i:s", $tmp_time);
78        $objQuery = new SC_Query();
79        $arrRet = $objQuery->select("order_date, create_date", "dtb_bat_order_daily", "order_date = ?", array($batch_date));
80        // ¤¹¤Ç¤Ë¥Ð¥Ã¥Á½èÍý¤¬½ªÎ»¤·¤Æ¤¤¤ë¤«¥Á¥§¥Ã¥¯¤¹¤ë¡£
81        if(count($arrRet) > 0) {
82            list($create_date) = split("\.", $arrRet[0]['create_date']);
83            list($order_date) = split("\.", $arrRet[0]['order_date']);
84            $create_time = strtotime($create_date);
85            $order_time = strtotime($order_date);
86            // ¥ª¡¼¥À¡¼³«»ÏÆü¤è¤ê°ìÆü°Ê¾å¸å¤Ë½¸·×¤µ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ï½¸·×¤·¤Ê¤ª¤µ¤Ê¤¤
87            if($order_time + 86400 < $create_time) {
88                gfPrintLog("EXIT BATCH $batch_date");
89            }
90        }
91        gfPrintLog("LOADING BATCH $batch_date");
92        lfBatOrderDaily($tmp_time);
93        lfBatOrderDailyHour($tmp_time);
94        lfBatOrderAge($tmp_time);
95    }
96}
97
98// ¥Ð¥Ã¥Á½¸·×ÍѤÎSQLʸ¤ò¼èÆÀ¤¹¤ë¡£
99function lfGetOrderDailySQL() {
100    $sql = "SELECT ";
101    $sql.= "COUNT(*) AS total_order, ";
102    $sql.= "SUM((SELECT COUNT(*) WHERE customer_id = 0)) AS nonmember, ";
103    $sql.= "SUM((SELECT COUNT(*) WHERE customer_id <> 0 GROUP BY customer_id)) AS member, ";
104    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1)) AS men, ";
105    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2)) AS women, ";
106    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1 AND customer_id <> 0)) AS men_member, ";
107    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1 AND customer_id = 0)) AS men_nonmember, ";
108    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2 AND customer_id <> 0)) AS women_member, ";
109    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2 AND customer_id = 0)) AS women_nonmember, ";
110    $sql.= "SUM(total) AS total, ";
111    $sql.= "int4(AVG(total)) AS total_average ";
112    $sql.= "FROM dtb_order AS T1 LEFT JOIN dtb_customer AS T2 USING ( customer_id ) ";
113    $sql.= "WHERE T1.delete = 0 AND T1.create_date BETWEEN ? AND ?";        // ¼õÃíºîÀ®Æü¤Ç¸¡º÷¤¹¤ë
114    return $sql;
115}
116
117// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(ÆüÊÌ)
118function lfBatOrderDaily($time) {
119    global $arrWDAY;
120   
121    $sql = lfGetOrderDailySQL();
122   
123    // ½¸·×ÂÐ¾ÝÆü¤ò¼èÆÀ¤¹¤ë
124    $date = date("Y-m-d", $time);
125   
126    $start = $date . " 00:00:00";
127    $end = $date . " 23:59:59";
128   
129    $objQuery = new SC_Query();
130    $arrRet = $objQuery->getall($sql, array($start, $end));
131       
132    $sqlval = $arrRet[0];
133   
134    // ¶õʸ»ú¤ò"0"¤ËÊÑ´¹
135    foreach($sqlval as $key => $val) {
136        if ($val == "") {
137            $sqlval[$key] = "0";
138        }
139    }
140   
141    $sqlval['order_date'] = $start;
142    $sqlval['year'] = date("Y", $time);
143    $sqlval['month'] = date("m", $time);
144    $sqlval['day'] = date("d", $time);
145    $sqlval['wday'] = date("w", $time);
146    $sqlval['key_day'] = sprintf("%02d/%02d/%02d", substr($sqlval['year'],2), $sqlval['month'], $sqlval['day']);
147    $sqlval['key_month'] = sprintf("%02d/%02d", substr($sqlval['year'],2), $sqlval['month']);
148    $sqlval['key_year'] = sprintf("%d", $sqlval['year']);
149    $sqlval['key_wday'] = sprintf("%s", $arrWDAY[$sqlval['wday']]);
150   
151    $objQuery->delete("dtb_bat_order_daily", "order_date = ?", array($start));
152    $objQuery->insert("dtb_bat_order_daily", $sqlval);
153}
154
155// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(»þ´ÖÊÌ)
156function lfBatOrderDailyHour($time) {
157   
158    $sql = lfGetOrderDailySQL();
159   
160    // ½¸·×ÂÐ¾ÝÆü¤ò¼èÆÀ¤¹¤ë
161    $date = date("Y-m-d", $time);
162    $objQuery = new SC_Query();
163   
164    $start = $date . " 00:00:00";
165    $objQuery->delete("dtb_bat_order_daily_hour", "order_date = ?", array($start));
166   
167    // 1»þ´ÖËè¤Ë½¸·×¤¹¤ë¡£
168    for($i = 0; $i < 24; $i++) {
169        $sdate = sprintf("%s %02d:00:00", $date, $i);
170        $edate = sprintf("%s %02d:59:59", $date, $i);
171        $arrRet = $objQuery->getall($sql, array($sdate, $edate));
172        $sqlval = $arrRet[0];
173        // ¶õʸ»ú¤ò"0"¤ËÊÑ´¹
174        foreach($sqlval as $key => $val) {
175            if ($val == "") {
176                $sqlval[$key] = "0";
177            }
178        }
179        $sqlval['order_date'] = $start;
180        $sqlval['hour'] = "$i";
181        $objQuery->insert("dtb_bat_order_daily_hour", $sqlval);
182    }   
183}
184
185// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(ǯÎðÊÌ)
186function lfBatOrderAge($time) {
187   
188    $age_loop = intval(BAT_ORDER_AGE / 10);
189   
190    // ǯÎð¤ÎÈϰϤò»ØÄꤷ¤Æ¥Ç¡¼¥¿Ãê½Ð
191    $sql.= "SELECT COUNT(*) AS order_count, SUM(total) AS total, int4(AVG(total)) AS total_average ";
192    $sql.= "FROM dtb_order ";
193   
194    // ½¸·×ÂÐ¾ÝÆü¤ò¼èÆÀ¤¹¤ë
195    $date = date("Y-m-d", $time);
196   
197    $start = $date . " 00:00:00";
198    $end = $date . " 23:59:59";
199   
200    $objQuery = new SC_Query();
201    $objQuery->delete("dtb_bat_order_daily_age", "order_date = ?", array($start));
202   
203    /* ²ñ°÷½¸·× */
204   
205    $base_where = "WHERE (create_date BETWEEN ? AND ?) AND customer_id <> 0 AND delete = 0 ";
206    $where = $base_where . " AND (to_number(to_char(age(current_timestamp, order_birth), 'YYY'), 999) BETWEEN ? AND ?) ";
207   
208    // ǯÎðËè¤Ë½¸·×¤¹¤ë¡£
209    for($i = 0; $i <= $age_loop; $i++) {
210        $start_age = $i * 10;
211        $end_age = $start_age + 9;
212        if($i >= $age_loop) {
213            $end_age = 999;
214        }
215        lfBatOrderAgeSub($sql . $where, $start, $end, $start_age, $end_age, 1);
216    }
217   
218    // ÃÂÀ¸ÆüÆþÎϤʤ·
219    $where = $base_where . " AND order_birth IS NULL ";
220    lfBatOrderAgeSub($sql . $where, $start, $end, NULL, NULL, 1);
221   
222    /* Èó²ñ°÷½¸·× */
223   
224    $base_where = "WHERE (create_date BETWEEN ? AND ?) AND customer_id = 0 AND delete = 0";
225    $where = $base_where . " AND (to_number(to_char(age(current_timestamp, order_birth), 'YYY'), 999) BETWEEN ? AND ?) ";
226   
227    // ǯÎðËè¤Ë½¸·×¤¹¤ë¡£
228    for($i = 0; $i <= $age_loop; $i++) {
229        $start_age = $i * 10;
230        $end_age = $start_age + 9;
231        if($i >= $age_loop) {
232            $end_age = 999;
233        }
234        lfBatOrderAgeSub($sql . $where, $start, $end, $start_age, $end_age, 0);
235    }
236   
237    // ÃÂÀ¸ÆüÆþÎϤʤ·
238    $where = $base_where . " AND order_birth IS NULL AND delete = 0";
239    lfBatOrderAgeSub($sql . $where, $start, $end, NULL, NULL, 0);   
240}
241
242// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(ǯÎðÊÌ) ÅÐÏ¿Éôʬ
243function lfBatOrderAgeSub($sql, $start, $end, $start_age, $end_age, $member) {
244    $objQuery = new SC_Query();
245   
246    if($start_age != NULL || $end_age != NULL) {
247        $arrRet = $objQuery->getall($sql, array($start, $end, $start_age, $end_age));
248    } else {
249        $arrRet = $objQuery->getall($sql, array($start, $end));
250    }
251    $sqlval = $arrRet[0];
252   
253    // ¶õʸ»ú¤ò"0"¤ËÊÑ´¹
254    foreach($sqlval as $key => $val) {
255        if ($val == "") {
256            $sqlval[$key] = "0";
257        }
258    }
259       
260    $sqlval['order_date'] = $start;
261    $sqlval['start_age'] = "$start_age";
262    $sqlval['end_age'] = "$end_age";
263    $sqlval['member'] = "$member";
264
265    $objQuery->insert("dtb_bat_order_daily_age", $sqlval);
266}
267
268?>
Note: See TracBrowser for help on using the repository browser.