source: branches/version-2_5-dev/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL.php @ 18789

Revision 18789, 20.4 KB checked in by nanasess, 12 years ago (diff)

DB_TYPE で条件分岐している箇所の抽象化(#801)

  • DB_TYPE で条件分岐している箇所の修正
  • SC_DB_DBFactory に関数を追加
    • getOrderYesterdaySql()
    • getOrderMonthSql()
    • getReviewYesterdaySql()
    • getSendHistoryWhereStartdateSql()
    • concatColumn()
  • SC_Utils::sfManualEscape() の実装を SC_Query::quote() に変更
  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id Revision Date
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
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
25require_once(CLASS_PATH . "db/SC_DB_DBFactory.php");
26
27/**
28 * MySQL 固有の処理をするクラス.
29 *
30 * このクラスを直接インスタンス化しないこと.
31 * 必ず SC_DB_DBFactory クラスを経由してインスタンス化する.
32 * また, SC_DB_DBFactory クラスの関数を必ずオーバーライドしている必要がある.
33 *
34 * @package DB
35 * @author LOCKON CO.,LTD.
36 * @version $Id:SC_DB_DBFactory_MYSQL.php 15267 2007-08-09 12:31:52Z nanasess $
37 */
38class SC_DB_DBFactory_MYSQL extends SC_DB_DBFactory {
39
40    /** SC_Query インスタンス */
41    var $objQuery;
42
43    /**
44     * DBのバージョンを取得する.
45     *
46     * @param string $dsn データソース名
47     * @return string データベースのバージョン
48     */
49    function sfGetDBVersion($dsn = "") {
50        $objQuery =& SC_Query::getSingletonInstance();
51        $val = $objQuery->getOne("select version()");
52        return "MySQL " . $val;
53    }
54
55    /**
56     * MySQL 用の SQL 文に変更する.
57     *
58     * @access private
59     * @param string $sql SQL 文
60     * @return string MySQL 用に置換した SQL 文
61     */
62    function sfChangeMySQL($sql){
63        // 改行、タブを1スペースに変換
64        $sql = preg_replace("/[\r\n\t]/"," ",$sql);
65        // view表をインラインビューに変換する
66        $sql = $this->sfChangeView($sql);
67        // ILIKE検索をLIKE検索に変換する
68        $sql = $this->sfChangeILIKE($sql);
69        // RANDOM()をRAND()に変換する
70        $sql = $this->sfChangeRANDOM($sql);
71        // TRUNCをTRUNCATEに変換する
72        $sql = $this->sfChangeTrunc($sql);
73        return $sql;
74    }
75
76    /**
77     * 文字コード情報を取得する
78     *
79     * @return array 文字コード情報
80     */
81    function getCharSet() {
82        $objQuery =& SC_Query::getSingletonInstance();
83        $arrRet = $objQuery->getAll("SHOW VARIABLES LIKE 'char%'");
84        return $arrRet;
85    }
86
87    /**
88     * テーブルの存在チェックを行う SQL 文を返す.
89     *
90     * @param string $table_name 存在チェックを行うテーブル名
91     * @return string テーブルの存在チェックを行う SQL 文
92     */
93    function getTableExistsSql($table_name) {
94        // XXX 何故かブレースホルダが使えない
95        $objQuery =& SC_Query::getSingletonInstance();
96        return "SHOW TABLE STATUS LIKE " . $objQuery->quote($table_name);
97    }
98
99    /**
100     * 昨日の売上高・売上件数を算出する SQL を返す.
101     *
102     * @param string $method SUM または COUNT
103     * @return string 昨日の売上高・売上件数を算出する SQL
104     */
105    function getOrderYesterdaySql($method) {
106        return "SELECT ".$method."(total) FROM dtb_order "
107              . "WHERE del_flg = 0 "
108                . "AND cast(create_date as date) = DATE_ADD(current_date, interval -1 day) "
109                . "AND status <> " . ORDER_CANCEL;
110    }
111
112    /**
113     * 当月の売上高・売上件数を算出する SQL を返す.
114     *
115     * @param string $method SUM または COUNT
116     * @return string 当月の売上高・売上件数を算出する SQL
117     */
118    function getOrderMonthSql($method) {
119        return "SELECT ".$method."(total) FROM dtb_order "
120              . "WHERE del_flg = 0 "
121                . "AND date_format(create_date, '%Y/%m') = ? "
122                . "AND date_format(create_date, '%Y/%m/%d') <> date_format(now(), '%Y/%m/%d') "
123                . "AND status <> " . ORDER_CANCEL;
124    }
125
126    /**
127     * 昨日のレビュー書き込み件数を算出する SQL を返す.
128     *
129     * @return string 昨日のレビュー書き込み件数を算出する SQL
130     */
131    function getReviewYesterdaySql() {
132        return "SELECT COUNT(*) FROM dtb_review AS A "
133          . "LEFT JOIN dtb_products AS B "
134                 . "ON A.product_id = B.product_id "
135              . "WHERE A.del_flg = 0 "
136                . "AND B.del_flg = 0 "
137                . "AND cast(A.create_date as date) = DATE_ADD(current_date, interval -1 day) "
138                . "AND cast(A.create_date as date) != current_date";
139    }
140
141    /**
142     * メール送信履歴の start_date の検索条件の SQL を返す.
143     *
144     * @return string 検索条件の SQL
145     */
146    function getSendHistoryWhereStartdateSql() {
147        return "start_date BETWEEN date_add(now(),INTERVAL -5 minute) AND date_add(now(),INTERVAL 5 minute)";
148    }
149
150    /**
151     * 文字列連結を行う.
152     *
153     * @param array $columns 連結を行うカラム名
154     * @return string 連結後の SQL 文
155     */
156    function concatColumn($columns) {
157        $sql = "concat(";
158        $i = 0;
159        $total = count($columns);
160        foreach ($columns as $column) {
161            $sql .= $column;
162            if ($i < $total -1) {
163                $sql .= ", ";
164            }
165            $i++;
166        }
167        $sql .= ")";
168        return $sql;
169    }
170
171    /**
172     * インデックスの検索結果を配列で返す.
173     *
174     * @param string $index_name インデックス名
175     * @param string $table_name テーブル名
176     * @return array インデックスの検索結果の配列
177     */
178    function getTableIndex($index_name, $table_name = "") {
179        $objQuery =& SC_Query::getSingletonInstance();
180        return $objQuery->getAll("SHOW INDEX FROM " . $table_name . " WHERE Key_name = ?",
181                                 array($index_name));
182    }
183
184    /**
185     * インデックスを作成する.
186     *
187     * @param string $index_name インデックス名
188     * @param string $table_name テーブル名
189     * @param string $col_name カラム名
190     * @param integer $length 作成するインデックスのバイト長
191     * @return void
192     */
193    function createTableIndex($index_name, $table_name, $col_name, $length = 0) {
194        $objQuery =& SC_Query::getSingletonInstance();
195        $objQuery->query("CREATE INDEX ? ON ? (?(?))", array($index_name, $table_name, $col_name, $length));
196    }
197
198    /**
199     * テーブルのカラム一覧を取得する.
200     *
201     * @param string $table_name テーブル名
202     * @return array テーブルのカラム一覧の配列
203     */
204    function sfGetColumnList($table_name) {
205        $objQuery =& SC_Query::getSingletonInstance();
206        $sql = "SHOW COLUMNS FROM " . $table_name;
207        $arrColList = $objQuery->getAll($sql);
208        $arrColList = SC_Utils_Ex::sfswaparray($arrColList);
209        return $arrColList["Field"];
210    }
211
212    /**
213     * テーブルを検索する.
214     *
215     * 引数に部分一致するテーブル名を配列で返す.
216     *
217     * @param string $expression 検索文字列
218     * @return array テーブル名の配列
219     */
220    function findTableNames($expression = "") {
221        $objQuery =& SC_Query::getSingletonInstance();
222        $sql = "SHOW TABLES LIKE ". $objQuery->quote("%" . $expression . "%");
223        $arrColList = $objQuery->getAll($sql);
224        $arrColList = SC_Utils_Ex::sfswaparray($arrColList, false);
225        return $arrColList[0];
226    }
227
228    /**
229     * View の WHERE 句を置換する.
230     *
231     * @param string $target 置換対象の文字列
232     * @param string $where 置換する文字列
233     * @param array $arrval WHERE 句の要素の配列
234     * @param string $option SQL 文の追加文字列
235     * @return string 置換後の SQL 文
236     */
237    function sfViewWhere($target, $where = "", $arrval = array(), $option = ""){
238
239        $arrWhere = split("[?]", $where);
240        $where_tmp = " WHERE " . $arrWhere[0];
241        for($i = 1; $i < count($arrWhere); $i++){
242            $where_tmp .= SC_Utils_Ex::sfQuoteSmart($arrval[$i - 1]) . $arrWhere[$i];
243        }
244        $arrWhere = $this->getWhereConverter();
245        $arrWhere[$target] = $where_tmp . " " . $option;
246        return $arrWhere[$target];
247    }
248
249    /**
250     * View をインラインビューに変換する.
251     *
252     * @access private
253     * @param string $sql SQL 文
254     * @return string インラインビューに変換した SQL 文
255     */
256    function sfChangeView($sql){
257
258        $arrViewTmp = $this->viewToSubQuery();
259
260            // viewのwhereを変換
261        foreach($arrViewTmp as $key => $val){
262            $arrViewTmp[$key] = strtr($arrViewTmp[$key], $this->getWhereConverter());
263        }
264
265            // viewを変換
266        $changesql = strtr($sql, $arrViewTmp);
267
268        return $changesql;
269    }
270
271    /**
272     * ILIKE句 を LIKE句へ変換する.
273     *
274     * @access private
275     * @param string $sql SQL文
276     * @return string 変換後の SQL 文
277     */
278    function sfChangeILIKE($sql){
279        $changesql = eregi_replace("(ILIKE )", "LIKE ", $sql);
280        return $changesql;
281    }
282
283    /**
284     * RANDOM() を RAND() に変換する.
285     *
286     * @access private
287     * @param string $sql SQL文
288     * @return string 変換後の SQL 文
289     */
290    function sfChangeRANDOM($sql){
291        $changesql = eregi_replace("( RANDOM)", " RAND", $sql);
292        return $changesql;
293    }
294
295    /**
296     * TRUNC() を TRUNCATE() に変換する.
297     *
298     * @access private
299     * @param string $sql SQL文
300     * @return string 変換後の SQL 文
301     */
302    function sfChangeTrunc($sql){
303        $changesql = eregi_replace("( TRUNC)", " TRUNCATE", $sql);
304        return $changesql;
305    }
306
307    /**
308     * WHERE 句置換用の配列を返す.
309     *
310     * @access private
311     * @return array WHERE 句置換用の配列
312     */
313    function getWhereConverter() {
314        return array(
315            "&&crscls_where&&" => "",
316            "&&crsprdcls_where&&" =>"",
317            "&&noncls_where&&" => "",
318            "&&allcls_where&&" => "",
319            "&&allclsdtl_where&&" => "",
320            "&&prdcls_where&&" => "",
321            "&&catcnt_where&&" => ""
322        );
323    }
324
325    /**
326     * View をサブクエリに変換するための配列を返す.
327     *
328     * @access private
329     * @return array View をサブクエリに変換するための配列
330     */
331    function viewToSubQuery() {
332
333        static $sql = array();
334
335        if (empty($sql)) {
336
337            $sql['vw_cross_class'] = <<< __EOS__
338                (
339                    SELECT
340                        T1.class_id AS class_id1,
341                        T2.class_id AS class_id2,
342                        T1.classcategory_id AS classcategory_id1,
343                        T2.classcategory_id AS classcategory_id2,
344                        T1.name AS name1,
345                        T2.name AS name2,
346                        T1.rank AS rank1,
347                        T2.rank AS rank2
348                    FROM
349                        dtb_classcategory AS T1,
350                        dtb_classcategory AS T2
351                )
352__EOS__;
353
354            $sql['vw_cross_products_class'] = <<< __EOS__
355                (
356                    SELECT
357                        T1.class_id1,
358                        T1.class_id2,
359                        T1.classcategory_id1,
360                        T1.classcategory_id2,
361                        T2.product_id,
362                        T1.name1,
363                        T1.name2,
364                        T2.product_code,
365                        T2.stock,
366                        T2.price01,
367                        T2.price02,
368                        T1.rank1,
369                        T1.rank2
370                    FROM
371                        {$sql['vw_cross_class']} AS T1
372                        LEFT JOIN dtb_products_class AS T2
373                            ON T1.classcategory_id1 = T2.classcategory_id1
374                            AND T1.classcategory_id2 = T2.classcategory_id2
375                )
376__EOS__;
377
378            $sql['vw_products_nonclass'] = <<< __EOS__
379                (
380                    SELECT *
381                    FROM
382                        dtb_products AS T1
383                        LEFT JOIN
384                        (
385                            SELECT
386                                product_id AS product_id_sub,
387                                product_code,
388                                price01,
389                                price02,
390                                stock,
391                                stock_unlimited,
392                                classcategory_id1,
393                                classcategory_id2
394                            FROM dtb_products_class
395                            WHERE
396                                classcategory_id1 = 0
397                                AND classcategory_id2 = 0
398                        ) AS T2
399                        ON T1.product_id = T2.product_id_sub
400                )
401__EOS__;
402
403            $sql['vw_products_allclass_detail'] = <<< __EOS__
404                (
405                    SELECT
406                        dtb_products.product_id,
407                        dtb_products.name,
408                        dtb_products.deliv_fee,
409                        dtb_products.sale_limit,
410                        dtb_products.maker_id,
411                        dtb_products.rank,
412                        dtb_products.status,
413                        dtb_products.product_flag,
414                        dtb_products.point_rate,
415                        dtb_products.comment1,
416                        dtb_products.comment2,
417                        dtb_products.comment3,
418                        dtb_products.comment4,
419                        dtb_products.comment5,
420                        dtb_products.comment6,
421                        dtb_products.note,
422                        dtb_products.file1,
423                        dtb_products.file2,
424                        dtb_products.file3,
425                        dtb_products.file4,
426                        dtb_products.file5,
427                        dtb_products.file6,
428                        dtb_products.main_list_comment,
429                        dtb_products.main_list_image,
430                        dtb_products.main_comment,
431                        dtb_products.main_image,
432                        dtb_products.main_large_image,
433                        dtb_products.sub_title1,
434                        dtb_products.sub_comment1,
435                        dtb_products.sub_image1,
436                        dtb_products.sub_large_image1,
437                        dtb_products.sub_title2,
438                        dtb_products.sub_comment2,
439                        dtb_products.sub_image2,
440                        dtb_products.sub_large_image2,
441                        dtb_products.sub_title3,
442                        dtb_products.sub_comment3,
443                        dtb_products.sub_image3,
444                        dtb_products.sub_large_image3,
445                        dtb_products.sub_title4,
446                        dtb_products.sub_comment4,
447                        dtb_products.sub_image4,
448                        dtb_products.sub_large_image4,
449                        dtb_products.sub_title5,
450                        dtb_products.sub_comment5,
451                        dtb_products.sub_image5,
452                        dtb_products.sub_large_image5,
453                        dtb_products.sub_title6,
454                        dtb_products.sub_comment6,
455                        dtb_products.sub_image6,
456                        dtb_products.sub_large_image6,
457                        dtb_products.del_flg,
458                        dtb_products.creator_id,
459                        dtb_products.create_date,
460                        dtb_products.update_date,
461                        dtb_products.deliv_date_id,
462                        dtb_products.down,
463                        dtb_products.down_filename,
464                        dtb_products.down_realfilename,
465                        T4.product_code_min,
466                        T4.product_code_max,
467                        T4.price01_min,
468                        T4.price01_max,
469                        T4.price02_min,
470                        T4.price02_max,
471                        T4.stock_min,
472                        T4.stock_max,
473                        T4.stock_unlimited_min,
474                        T4.stock_unlimited_max,
475                        T4.class_count
476                    FROM
477                        dtb_products
478                        LEFT JOIN
479                            (
480                                SELECT
481                                    product_id,
482                                    MIN(product_code) AS product_code_min,
483                                    MAX(product_code) AS product_code_max,
484                                    MIN(price01) AS price01_min,
485                                    MAX(price01) AS price01_max,
486                                    MIN(price02) AS price02_min,
487                                    MAX(price02) AS price02_max,
488                                    MIN(stock) AS stock_min,
489                                    MAX(stock) AS stock_max,
490                                    MIN(stock_unlimited) AS stock_unlimited_min,
491                                    MAX(stock_unlimited) AS stock_unlimited_max,
492                                    COUNT(*) as class_count
493                                FROM dtb_products_class
494                                GROUP BY product_id
495                            ) AS T4
496                            ON dtb_products.product_id = T4.product_id
497                )
498__EOS__;
499
500            $sql['vw_products_allclass'] = <<< __EOS__
501                (
502                    SELECT
503                        alldtl.*,
504                        dtb_category.rank AS category_rank,
505                        T2.category_id,
506                        T2.rank AS product_rank
507                    FROM
508                        {$sql['vw_products_allclass_detail']} AS alldtl
509                        LEFT JOIN
510                            dtb_product_categories AS T2
511                            ON alldtl.product_id = T2.product_id
512                        LEFT JOIN
513                            dtb_category
514                            ON T2.category_id = dtb_category.category_id
515                )
516__EOS__;
517
518            $sql['vw_product_class'] = <<< __EOS__
519                (SELECT * FROM
520                (SELECT T3.product_class_id, T3.product_id AS product_id_sub, classcategory_id1, classcategory_id2,
521                T3.rank AS rank1, T4.rank AS rank2, T3.class_id AS class_id1, T4.class_id AS class_id2,
522                stock, price01, price02, stock_unlimited, product_code
523                FROM ( SELECT
524                        T1.product_class_id,
525                        T1.product_id,
526                        classcategory_id1,
527                        classcategory_id2,
528                        T2.rank,
529                        T2.class_id,
530                        stock,
531                        price01,
532                        price02,
533                        stock_unlimited,
534                        product_code
535                 FROM (dtb_products_class AS T1 LEFT JOIN dtb_classcategory AS T2
536                ON T1.classcategory_id1 = T2.classcategory_id))
537                AS T3 LEFT JOIN dtb_classcategory AS T4
538                ON T3.classcategory_id2 = T4.classcategory_id) AS T5 LEFT JOIN dtb_products AS T6
539                ON product_id_sub = T6.product_id)
540__EOS__;
541
542            $sql['vw_category_count'] = <<< __EOS__
543                (SELECT T1.category_id, T1.category_name, T1.parent_category_id, T1.level, T1.rank, T2.product_count
544                FROM dtb_category AS T1 LEFT JOIN dtb_category_total_count AS T2
545                ON T1.category_id = T2.category_id)
546__EOS__;
547
548            $sql['vw_download_class'] = <<< __EOS__
549                (SELECT p.product_id AS product_id, p.down_realfilename AS down_realfilename , p.down_filename AS down_filename, od.order_id AS order_id, o.customer_id AS customer_id, o.commit_date AS commit_date, o.status AS status FROM
550                    dtb_products p, dtb_order_detail od, dtb_order o
551                WHERE p.product_id = od.product_id AND od.order_id = o.order_id)
552__EOS__;
553        }
554
555        return $sql;
556
557    }
558}
559?>
Note: See TracBrowser for help on using the repository browser.