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

Revision 2852, 6.8 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    print("term:" . $term);
31   
32    $now_time = time();
33   
34    // ¥°¥é¥Õ²èÁü¤Îºï½ü
35    $path = GRAPH_DIR . "*.png";
36    system ("rm -rf $path");
37   
38    // ºï½ü¤µ¤ì¤¿¼õÃí¥Ç¡¼¥¿¤Î¼õÃí¾ÜºÙ¾ðÊó¤Îºï½ü
39    $objQuery = new SC_Query();
40    $where = "order_id IN (SELECT order_id FROM dtb_order WHERE delete = 1)";
41    $objQuery->delete("dtb_order_detail", $where);
42
43    // ½¸·×
44    for ($i = $start; $i < $term; $i++) {
45        // ´ðËÜ»þ´Ö¤«¤é1Æüʬ¤µ¤«¤Î¤Ü¤ë
46        $tmp_time = $now_time - ($i * 24 * 3600);
47               
48        $batch_date = date("Y/m/d", $tmp_time);
49       
50        // ºÇ¸å¤Î¥Ð¥Ã¥Á¼Â¹Ô¤«¤éLOAD_BATCH_PASSÉ÷вᤷ¤Æ¤¤¤Ê¤¤¤È¼Â¹Ô¤·¤Ê¤¤¡£
51        $batch_pass = date("Y/m/d H:m:s", $tmp_time - LOAD_BATCH_PASS);
52        $objQuery = new SC_Query();
53        $count = $objQuery->count("dtb_bat_order_daily", "create_date > ?", $batch_pass);
54        $objQuery->getLastQuery();
55        if($count > 0) {
56            gfPrintLog("LAST BATCH $batch_pass -> EXIT BATCH $batch_date");
57            return;
58        }
59       
60        gfPrintLog("LOADING BATCH $batch_date");
61                   
62        lfBatOrderDaily($tmp_time);
63        lfBatOrderDailyHour($tmp_time);
64        lfBatOrderAge($tmp_time);
65    }
66}
67
68// ¥Ð¥Ã¥Á½¸·×ÍѤÎSQLʸ¤ò¼èÆÀ¤¹¤ë¡£
69function lfGetOrderDailySQL() {
70    $sql = "SELECT ";
71    $sql.= "COUNT(*) AS total_order, ";
72    $sql.= "SUM((SELECT COUNT(*) WHERE customer_id = 0)) AS nonmember, ";
73    $sql.= "SUM((SELECT COUNT(*) WHERE customer_id <> 0 GROUP BY customer_id)) AS member, ";
74    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1)) AS men, ";
75    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2)) AS women, ";
76    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1 AND customer_id <> 0)) AS men_member, ";
77    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 1 AND customer_id = 0)) AS men_nonmember, ";
78    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2 AND customer_id <> 0)) AS women_member, ";
79    $sql.= "SUM((SELECT COUNT(*) WHERE order_sex = 2 AND customer_id = 0)) AS women_nonmember, ";
80    $sql.= "SUM(total) AS total, ";
81    $sql.= "int4(AVG(total)) AS total_average ";
82    $sql.= "FROM dtb_order AS T1 LEFT JOIN dtb_customer AS T2 USING ( customer_id ) ";
83    $sql.= "WHERE T1.delete = 0 AND T1.create_date BETWEEN ? AND ?";        // ¼õÃíºîÀ®Æü¤Ç¸¡º÷¤¹¤ë
84    return $sql;
85}
86
87// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(ÆüÊÌ)
88function lfBatOrderDaily($time) {
89    global $arrWDAY;
90   
91    $sql = lfGetOrderDailySQL();
92   
93    // ½¸·×ÂÐ¾ÝÆü¤ò¼èÆÀ¤¹¤ë
94    $date = date("Y-m-d", $time);
95   
96    $start = $date . " 00:00:00";
97    $end = $date . " 23:59:59";
98   
99    $objQuery = new SC_Query();
100    $arrRet = $objQuery->getall($sql, array($start, $end));
101       
102    $sqlval = $arrRet[0];
103   
104    // ¶õʸ»ú¤ò"0"¤ËÊÑ´¹
105    foreach($sqlval as $key => $val) {
106        if ($val == "") {
107            $sqlval[$key] = "0";
108        }
109    }
110   
111    $sqlval['order_date'] = $start;
112    $sqlval['year'] = date("Y", $time);
113    $sqlval['month'] = date("m", $time);
114    $sqlval['day'] = date("d", $time);
115    $sqlval['wday'] = date("w", $time);
116    $sqlval['key_day'] = sprintf("%02d/%02d/%02d", substr($sqlval['year'],2), $sqlval['month'], $sqlval['day']);
117    $sqlval['key_month'] = sprintf("%02d/%02d", substr($sqlval['year'],2), $sqlval['month']);
118    $sqlval['key_year'] = sprintf("%d", $sqlval['year']);
119    $sqlval['key_wday'] = sprintf("%s", $arrWDAY[$sqlval['wday']]);
120   
121    $objQuery->delete("dtb_bat_order_daily", "order_date = ?", array($start));
122    $objQuery->insert("dtb_bat_order_daily", $sqlval);
123}
124
125// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(»þ´ÖÊÌ)
126function lfBatOrderDailyHour($time) {
127   
128    $sql = lfGetOrderDailySQL();
129   
130    // ½¸·×ÂÐ¾ÝÆü¤ò¼èÆÀ¤¹¤ë
131    $date = date("Y-m-d", $time);
132    $objQuery = new SC_Query();
133   
134    $start = $date . " 00:00:00";
135    $objQuery->delete("dtb_bat_order_daily_hour", "order_date = ?", array($start));
136   
137    // 1»þ´ÖËè¤Ë½¸·×¤¹¤ë¡£
138    for($i = 0; $i < 24; $i++) {
139        $sdate = sprintf("%s %02d:00:00", $date, $i);
140        $edate = sprintf("%s %02d:59:59", $date, $i);
141        $arrRet = $objQuery->getall($sql, array($sdate, $edate));
142        $sqlval = $arrRet[0];
143        // ¶õʸ»ú¤ò"0"¤ËÊÑ´¹
144        foreach($sqlval as $key => $val) {
145            if ($val == "") {
146                $sqlval[$key] = "0";
147            }
148        }
149        $sqlval['order_date'] = $start;
150        $sqlval['hour'] = "$i";
151        $objQuery->insert("dtb_bat_order_daily_hour", $sqlval);
152    }   
153}
154
155// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(ǯÎðÊÌ)
156function lfBatOrderAge($time) {
157   
158    $age_loop = intval(BAT_ORDER_AGE / 10);
159   
160    // ǯÎð¤ÎÈϰϤò»ØÄꤷ¤Æ¥Ç¡¼¥¿Ãê½Ð
161    $sql.= "SELECT COUNT(*) AS order_count, SUM(total) AS total, int4(AVG(total)) AS total_average ";
162    $sql.= "FROM dtb_order ";
163   
164    // ½¸·×ÂÐ¾ÝÆü¤ò¼èÆÀ¤¹¤ë
165    $date = date("Y-m-d", $time);
166   
167    $start = $date . " 00:00:00";
168    $end = $date . " 23:59:59";
169   
170    $objQuery = new SC_Query();
171    $objQuery->delete("dtb_bat_order_daily_age", "order_date = ?", array($start));
172   
173    /* ²ñ°÷½¸·× */
174   
175    $base_where = "WHERE (create_date BETWEEN ? AND ?) AND customer_id <> 0 AND delete = 0 ";
176    $where = $base_where . " AND (to_number(to_char(age(current_timestamp, order_birth), 'YYY'), 999) BETWEEN ? AND ?) ";
177   
178    // ǯÎðËè¤Ë½¸·×¤¹¤ë¡£
179    for($i = 0; $i <= $age_loop; $i++) {
180        $start_age = $i * 10;
181        $end_age = $start_age + 9;
182        if($i >= $age_loop) {
183            $end_age = 999;
184        }
185        lfBatOrderAgeSub($sql . $where, $start, $end, $start_age, $end_age, 1);
186    }
187   
188    // ÃÂÀ¸ÆüÆþÎϤʤ·
189    $where = $base_where . " AND order_birth IS NULL ";
190    lfBatOrderAgeSub($sql . $where, $start, $end, NULL, NULL, 1);
191   
192    /* Èó²ñ°÷½¸·× */
193   
194    $base_where = "WHERE (create_date BETWEEN ? AND ?) AND customer_id = 0 AND delete = 0";
195    $where = $base_where . " AND (to_number(to_char(age(current_timestamp, order_birth), 'YYY'), 999) BETWEEN ? AND ?) ";
196   
197    // ǯÎðËè¤Ë½¸·×¤¹¤ë¡£
198    for($i = 0; $i <= $age_loop; $i++) {
199        $start_age = $i * 10;
200        $end_age = $start_age + 9;
201        if($i >= $age_loop) {
202            $end_age = 999;
203        }
204        lfBatOrderAgeSub($sql . $where, $start, $end, $start_age, $end_age, 0);
205    }
206   
207    // ÃÂÀ¸ÆüÆþÎϤʤ·
208    $where = $base_where . " AND order_birth IS NULL AND delete = 0";
209    lfBatOrderAgeSub($sql . $where, $start, $end, NULL, NULL, 0);   
210}
211
212// Çä¾å¤²½¸·×¥Ð¥Ã¥Á½èÍý(ǯÎðÊÌ) ÅÐÏ¿Éôʬ
213function lfBatOrderAgeSub($sql, $start, $end, $start_age, $end_age, $member) {
214    $objQuery = new SC_Query();
215   
216    if($start_age != NULL || $end_age != NULL) {
217        $arrRet = $objQuery->getall($sql, array($start, $end, $start_age, $end_age));
218    } else {
219        $arrRet = $objQuery->getall($sql, array($start, $end));
220    }
221    $sqlval = $arrRet[0];
222   
223    // ¶õʸ»ú¤ò"0"¤ËÊÑ´¹
224    foreach($sqlval as $key => $val) {
225        if ($val == "") {
226            $sqlval[$key] = "0";
227        }
228    }
229       
230    $sqlval['order_date'] = $start;
231    $sqlval['start_age'] = "$start_age";
232    $sqlval['end_age'] = "$end_age";
233    $sqlval['member'] = "$member";
234
235    $objQuery->insert("dtb_bat_order_daily_age", $sqlval);
236}
237
238?>
Note: See TracBrowser for help on using the repository browser.