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

Revision 18790, 18.9 KB checked in by nanasess, 12 years ago (diff)

#801 の改善に伴い MDB2 の関数に置き替えと, 未使用関数の削除

  • SC_Query
    • get_auto_increment() を削除
    • listSequences() を追加
    • listTables() を追加
    • listTableFields() を追加
    • listTableIndexes() を追加
  • SC_DB_DBFactory
    • getTableExistsSql() を削除
    • getTableIndex() を削除
    • createTableIndex() を削除
    • sfGetColumnList(), findTableNames() に @deprecated コメント追加
  • SC_Helper_DB
    • sfTabaleExists() を削除
    • sfIndexExists() を削除
    • 削除した関数の使用箇所を修正
  • SC_Helper_Session
    • sfTabaleExists() を使用していた箇所の修正
  • html/install/index.php
    • sfTabaleExists() を使用していた箇所の修正
  • 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 $method SUM または COUNT
91     * @return string 昨日の売上高・売上件数を算出する SQL
92     */
93    function getOrderYesterdaySql($method) {
94        return "SELECT ".$method."(total) FROM dtb_order "
95              . "WHERE del_flg = 0 "
96                . "AND cast(create_date as date) = DATE_ADD(current_date, interval -1 day) "
97                . "AND status <> " . ORDER_CANCEL;
98    }
99
100    /**
101     * 当月の売上高・売上件数を算出する SQL を返す.
102     *
103     * @param string $method SUM または COUNT
104     * @return string 当月の売上高・売上件数を算出する SQL
105     */
106    function getOrderMonthSql($method) {
107        return "SELECT ".$method."(total) FROM dtb_order "
108              . "WHERE del_flg = 0 "
109                . "AND date_format(create_date, '%Y/%m') = ? "
110                . "AND date_format(create_date, '%Y/%m/%d') <> date_format(now(), '%Y/%m/%d') "
111                . "AND status <> " . ORDER_CANCEL;
112    }
113
114    /**
115     * 昨日のレビュー書き込み件数を算出する SQL を返す.
116     *
117     * @return string 昨日のレビュー書き込み件数を算出する SQL
118     */
119    function getReviewYesterdaySql() {
120        return "SELECT COUNT(*) FROM dtb_review AS A "
121          . "LEFT JOIN dtb_products AS B "
122                 . "ON A.product_id = B.product_id "
123              . "WHERE A.del_flg = 0 "
124                . "AND B.del_flg = 0 "
125                . "AND cast(A.create_date as date) = DATE_ADD(current_date, interval -1 day) "
126                . "AND cast(A.create_date as date) != current_date";
127    }
128
129    /**
130     * メール送信履歴の start_date の検索条件の SQL を返す.
131     *
132     * @return string 検索条件の SQL
133     */
134    function getSendHistoryWhereStartdateSql() {
135        return "start_date BETWEEN date_add(now(),INTERVAL -5 minute) AND date_add(now(),INTERVAL 5 minute)";
136    }
137
138    /**
139     * 文字列連結を行う.
140     *
141     * @param array $columns 連結を行うカラム名
142     * @return string 連結後の SQL 文
143     */
144    function concatColumn($columns) {
145        $sql = "concat(";
146        $i = 0;
147        $total = count($columns);
148        foreach ($columns as $column) {
149            $sql .= $column;
150            if ($i < $total -1) {
151                $sql .= ", ";
152            }
153            $i++;
154        }
155        $sql .= ")";
156        return $sql;
157    }
158
159    /**
160     * テーブルのカラム一覧を取得する.
161     *
162     * @deprecated SC_Query::listTableFields() を使用してください
163     * @param string $table_name テーブル名
164     * @return array テーブルのカラム一覧の配列
165     */
166    function sfGetColumnList($table_name) {
167        $objQuery =& SC_Query::getSingletonInstance();
168        $sql = "SHOW COLUMNS FROM " . $table_name;
169        $arrColList = $objQuery->getAll($sql);
170        $arrColList = SC_Utils_Ex::sfswaparray($arrColList);
171        return $arrColList["Field"];
172    }
173
174    /**
175     * テーブルを検索する.
176     *
177     * 引数に部分一致するテーブル名を配列で返す.
178     *
179     * @param string $expression 検索文字列
180     * @return array テーブル名の配列
181     */
182    function findTableNames($expression = "") {
183        $objQuery =& SC_Query::getSingletonInstance();
184        $sql = "SHOW TABLES LIKE ". $objQuery->quote("%" . $expression . "%");
185        $arrColList = $objQuery->getAll($sql);
186        $arrColList = SC_Utils_Ex::sfswaparray($arrColList, false);
187        return $arrColList[0];
188    }
189
190    /**
191     * View の WHERE 句を置換する.
192     *
193     * @param string $target 置換対象の文字列
194     * @param string $where 置換する文字列
195     * @param array $arrval WHERE 句の要素の配列
196     * @param string $option SQL 文の追加文字列
197     * @return string 置換後の SQL 文
198     */
199    function sfViewWhere($target, $where = "", $arrval = array(), $option = ""){
200
201        $arrWhere = split("[?]", $where);
202        $where_tmp = " WHERE " . $arrWhere[0];
203        for($i = 1; $i < count($arrWhere); $i++){
204            $where_tmp .= SC_Utils_Ex::sfQuoteSmart($arrval[$i - 1]) . $arrWhere[$i];
205        }
206        $arrWhere = $this->getWhereConverter();
207        $arrWhere[$target] = $where_tmp . " " . $option;
208        return $arrWhere[$target];
209    }
210
211    /**
212     * View をインラインビューに変換する.
213     *
214     * @access private
215     * @param string $sql SQL 文
216     * @return string インラインビューに変換した SQL 文
217     */
218    function sfChangeView($sql){
219
220        $arrViewTmp = $this->viewToSubQuery();
221
222            // viewのwhereを変換
223        foreach($arrViewTmp as $key => $val){
224            $arrViewTmp[$key] = strtr($arrViewTmp[$key], $this->getWhereConverter());
225        }
226
227            // viewを変換
228        $changesql = strtr($sql, $arrViewTmp);
229
230        return $changesql;
231    }
232
233    /**
234     * ILIKE句 を LIKE句へ変換する.
235     *
236     * @access private
237     * @param string $sql SQL文
238     * @return string 変換後の SQL 文
239     */
240    function sfChangeILIKE($sql){
241        $changesql = eregi_replace("(ILIKE )", "LIKE ", $sql);
242        return $changesql;
243    }
244
245    /**
246     * RANDOM() を RAND() に変換する.
247     *
248     * @access private
249     * @param string $sql SQL文
250     * @return string 変換後の SQL 文
251     */
252    function sfChangeRANDOM($sql){
253        $changesql = eregi_replace("( RANDOM)", " RAND", $sql);
254        return $changesql;
255    }
256
257    /**
258     * TRUNC() を TRUNCATE() に変換する.
259     *
260     * @access private
261     * @param string $sql SQL文
262     * @return string 変換後の SQL 文
263     */
264    function sfChangeTrunc($sql){
265        $changesql = eregi_replace("( TRUNC)", " TRUNCATE", $sql);
266        return $changesql;
267    }
268
269    /**
270     * WHERE 句置換用の配列を返す.
271     *
272     * @access private
273     * @return array WHERE 句置換用の配列
274     */
275    function getWhereConverter() {
276        return array(
277            "&&crscls_where&&" => "",
278            "&&crsprdcls_where&&" =>"",
279            "&&noncls_where&&" => "",
280            "&&allcls_where&&" => "",
281            "&&allclsdtl_where&&" => "",
282            "&&prdcls_where&&" => "",
283            "&&catcnt_where&&" => ""
284        );
285    }
286
287    /**
288     * View をサブクエリに変換するための配列を返す.
289     *
290     * @access private
291     * @return array View をサブクエリに変換するための配列
292     */
293    function viewToSubQuery() {
294
295        static $sql = array();
296
297        if (empty($sql)) {
298
299            $sql['vw_cross_class'] = <<< __EOS__
300                (
301                    SELECT
302                        T1.class_id AS class_id1,
303                        T2.class_id AS class_id2,
304                        T1.classcategory_id AS classcategory_id1,
305                        T2.classcategory_id AS classcategory_id2,
306                        T1.name AS name1,
307                        T2.name AS name2,
308                        T1.rank AS rank1,
309                        T2.rank AS rank2
310                    FROM
311                        dtb_classcategory AS T1,
312                        dtb_classcategory AS T2
313                )
314__EOS__;
315
316            $sql['vw_cross_products_class'] = <<< __EOS__
317                (
318                    SELECT
319                        T1.class_id1,
320                        T1.class_id2,
321                        T1.classcategory_id1,
322                        T1.classcategory_id2,
323                        T2.product_id,
324                        T1.name1,
325                        T1.name2,
326                        T2.product_code,
327                        T2.stock,
328                        T2.price01,
329                        T2.price02,
330                        T1.rank1,
331                        T1.rank2
332                    FROM
333                        {$sql['vw_cross_class']} AS T1
334                        LEFT JOIN dtb_products_class AS T2
335                            ON T1.classcategory_id1 = T2.classcategory_id1
336                            AND T1.classcategory_id2 = T2.classcategory_id2
337                )
338__EOS__;
339
340            $sql['vw_products_nonclass'] = <<< __EOS__
341                (
342                    SELECT *
343                    FROM
344                        dtb_products AS T1
345                        LEFT JOIN
346                        (
347                            SELECT
348                                product_id AS product_id_sub,
349                                product_code,
350                                price01,
351                                price02,
352                                stock,
353                                stock_unlimited,
354                                classcategory_id1,
355                                classcategory_id2
356                            FROM dtb_products_class
357                            WHERE
358                                classcategory_id1 = 0
359                                AND classcategory_id2 = 0
360                        ) AS T2
361                        ON T1.product_id = T2.product_id_sub
362                )
363__EOS__;
364
365            $sql['vw_products_allclass_detail'] = <<< __EOS__
366                (
367                    SELECT
368                        dtb_products.product_id,
369                        dtb_products.name,
370                        dtb_products.deliv_fee,
371                        dtb_products.sale_limit,
372                        dtb_products.maker_id,
373                        dtb_products.rank,
374                        dtb_products.status,
375                        dtb_products.product_flag,
376                        dtb_products.point_rate,
377                        dtb_products.comment1,
378                        dtb_products.comment2,
379                        dtb_products.comment3,
380                        dtb_products.comment4,
381                        dtb_products.comment5,
382                        dtb_products.comment6,
383                        dtb_products.note,
384                        dtb_products.file1,
385                        dtb_products.file2,
386                        dtb_products.file3,
387                        dtb_products.file4,
388                        dtb_products.file5,
389                        dtb_products.file6,
390                        dtb_products.main_list_comment,
391                        dtb_products.main_list_image,
392                        dtb_products.main_comment,
393                        dtb_products.main_image,
394                        dtb_products.main_large_image,
395                        dtb_products.sub_title1,
396                        dtb_products.sub_comment1,
397                        dtb_products.sub_image1,
398                        dtb_products.sub_large_image1,
399                        dtb_products.sub_title2,
400                        dtb_products.sub_comment2,
401                        dtb_products.sub_image2,
402                        dtb_products.sub_large_image2,
403                        dtb_products.sub_title3,
404                        dtb_products.sub_comment3,
405                        dtb_products.sub_image3,
406                        dtb_products.sub_large_image3,
407                        dtb_products.sub_title4,
408                        dtb_products.sub_comment4,
409                        dtb_products.sub_image4,
410                        dtb_products.sub_large_image4,
411                        dtb_products.sub_title5,
412                        dtb_products.sub_comment5,
413                        dtb_products.sub_image5,
414                        dtb_products.sub_large_image5,
415                        dtb_products.sub_title6,
416                        dtb_products.sub_comment6,
417                        dtb_products.sub_image6,
418                        dtb_products.sub_large_image6,
419                        dtb_products.del_flg,
420                        dtb_products.creator_id,
421                        dtb_products.create_date,
422                        dtb_products.update_date,
423                        dtb_products.deliv_date_id,
424                        dtb_products.down,
425                        dtb_products.down_filename,
426                        dtb_products.down_realfilename,
427                        T4.product_code_min,
428                        T4.product_code_max,
429                        T4.price01_min,
430                        T4.price01_max,
431                        T4.price02_min,
432                        T4.price02_max,
433                        T4.stock_min,
434                        T4.stock_max,
435                        T4.stock_unlimited_min,
436                        T4.stock_unlimited_max,
437                        T4.class_count
438                    FROM
439                        dtb_products
440                        LEFT JOIN
441                            (
442                                SELECT
443                                    product_id,
444                                    MIN(product_code) AS product_code_min,
445                                    MAX(product_code) AS product_code_max,
446                                    MIN(price01) AS price01_min,
447                                    MAX(price01) AS price01_max,
448                                    MIN(price02) AS price02_min,
449                                    MAX(price02) AS price02_max,
450                                    MIN(stock) AS stock_min,
451                                    MAX(stock) AS stock_max,
452                                    MIN(stock_unlimited) AS stock_unlimited_min,
453                                    MAX(stock_unlimited) AS stock_unlimited_max,
454                                    COUNT(*) as class_count
455                                FROM dtb_products_class
456                                GROUP BY product_id
457                            ) AS T4
458                            ON dtb_products.product_id = T4.product_id
459                )
460__EOS__;
461
462            $sql['vw_products_allclass'] = <<< __EOS__
463                (
464                    SELECT
465                        alldtl.*,
466                        dtb_category.rank AS category_rank,
467                        T2.category_id,
468                        T2.rank AS product_rank
469                    FROM
470                        {$sql['vw_products_allclass_detail']} AS alldtl
471                        LEFT JOIN
472                            dtb_product_categories AS T2
473                            ON alldtl.product_id = T2.product_id
474                        LEFT JOIN
475                            dtb_category
476                            ON T2.category_id = dtb_category.category_id
477                )
478__EOS__;
479
480            $sql['vw_product_class'] = <<< __EOS__
481                (SELECT * FROM
482                (SELECT T3.product_class_id, T3.product_id AS product_id_sub, classcategory_id1, classcategory_id2,
483                T3.rank AS rank1, T4.rank AS rank2, T3.class_id AS class_id1, T4.class_id AS class_id2,
484                stock, price01, price02, stock_unlimited, product_code
485                FROM ( SELECT
486                        T1.product_class_id,
487                        T1.product_id,
488                        classcategory_id1,
489                        classcategory_id2,
490                        T2.rank,
491                        T2.class_id,
492                        stock,
493                        price01,
494                        price02,
495                        stock_unlimited,
496                        product_code
497                 FROM (dtb_products_class AS T1 LEFT JOIN dtb_classcategory AS T2
498                ON T1.classcategory_id1 = T2.classcategory_id))
499                AS T3 LEFT JOIN dtb_classcategory AS T4
500                ON T3.classcategory_id2 = T4.classcategory_id) AS T5 LEFT JOIN dtb_products AS T6
501                ON product_id_sub = T6.product_id)
502__EOS__;
503
504            $sql['vw_category_count'] = <<< __EOS__
505                (SELECT T1.category_id, T1.category_name, T1.parent_category_id, T1.level, T1.rank, T2.product_count
506                FROM dtb_category AS T1 LEFT JOIN dtb_category_total_count AS T2
507                ON T1.category_id = T2.category_id)
508__EOS__;
509
510            $sql['vw_download_class'] = <<< __EOS__
511                (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
512                    dtb_products p, dtb_order_detail od, dtb_order o
513                WHERE p.product_id = od.product_id AND od.order_id = o.order_id)
514__EOS__;
515        }
516
517        return $sql;
518
519    }
520}
521?>
Note: See TracBrowser for help on using the repository browser.