source: branches/comu-ver2/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL.php @ 18135

Revision 18135, 16.2 KB checked in by Seasoft, 15 years ago (diff)

MySQL の vw_products_nonclass のロジックを PostgreSQL のもので置換する。

  • 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-2007 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    /**
41     * DBのバージョンを取得する.
42     *
43     * @param string $dsn データソース名
44     * @return string データベースのバージョン
45     */
46    function sfGetDBVersion($dsn = "") {
47        $objQuery = new SC_Query($this->getDSN($dsn), true, true);
48        $val = $objQuery->getOne("select version()");
49        return "MySQL " . $val;
50    }
51
52    /**
53     * MySQL 用の SQL 文に変更する.
54     *
55     * @access private
56     * @param string $sql SQL 文
57     * @return string MySQL 用に置換した SQL 文
58     */
59    function sfChangeMySQL($sql){
60        // 改行、タブを1スペースに変換
61        $sql = preg_replace("/[\r\n\t]/"," ",$sql);
62        // view表をインラインビューに変換する
63        $sql = $this->sfChangeView($sql);
64        // ILIKE検索をLIKE検索に変換する
65        $sql = $this->sfChangeILIKE($sql);
66        // RANDOM()をRAND()に変換する
67        $sql = $this->sfChangeRANDOM($sql);
68        // TRUNCをTRUNCATEに変換する
69        $sql = $this->sfChangeTrunc($sql);
70        return $sql;
71    }
72   
73    /**
74     * 文字コード情報を取得する
75     *
76     * @return array 文字コード情報
77     */
78    function getCharSet() {
79        $objQuery = new SC_Query();
80        $arrRet = $objQuery->getAll("SHOW VARIABLES LIKE 'char%'");
81        return $arrRet;
82    }
83   
84    /**
85     * テーブルの存在チェックを行う SQL 文を返す.
86     *
87     * @return string テーブルの存在チェックを行う SQL 文
88     */
89    function getTableExistsSql() {
90        return "SHOW TABLE STATUS LIKE ?";
91    }
92
93    /**
94     * インデックスの検索結果を配列で返す.
95     *
96     * @param string $index_name インデックス名
97     * @param string $table_name テーブル名
98     * @return array インデックスの検索結果の配列
99     */
100    function getTableIndex($index_name, $table_name = "") {
101        $objQuery = new SC_Query("", true, true);
102        return $objQuery->getAll("SHOW INDEX FROM " . $table_name . " WHERE Key_name = ?",
103                                 array($index_name));
104    }
105
106    /**
107     * インデックスを作成する.
108     *
109     * @param string $index_name インデックス名
110     * @param string $table_name テーブル名
111     * @param string $col_name カラム名
112     * @param integer $length 作成するインデックスのバイト長
113     * @return void
114     */
115    function createTableIndex($index_name, $table_name, $col_name, $length = 0) {
116        $objQuery = new SC_Query($dsn, true, true);
117        $objQuery->query("CREATE INDEX ? ON ? (?(?))", array($index_name, $table_name, $col_name, $length));
118    }
119
120    /**
121     * テーブルのカラム一覧を取得する.
122     *
123     * @param string $table_name テーブル名
124     * @return array テーブルのカラム一覧の配列
125     */
126    function sfGetColumnList($table_name) {
127        $objQuery = new SC_Query();
128        $sql = "SHOW COLUMNS FROM " . $table_name;
129        $arrColList = $objQuery->getAll($sql);
130        $arrColList = SC_Utils_Ex::sfswaparray($arrColList);
131        return $arrColList["Field"];
132    }
133
134    /**
135     * テーブルを検索する.
136     *
137     * 引数に部分一致するテーブル名を配列で返す.
138     *
139     * @param string $expression 検索文字列
140     * @return array テーブル名の配列
141     */
142    function findTableNames($expression = "") {
143        $objQuery = new SC_Query();
144        $sql = "SHOW TABLES LIKE ?";
145        $arrColList = $objQuery->getAll($sql, array("%" . $expression . "%"));
146        $arrColList = SC_Utils_Ex::sfswaparray($arrColList, false);
147        return $arrColList[0];
148    }
149
150    /**
151     * View の WHERE 句を置換する.
152     *
153     * @param string $target 置換対象の文字列
154     * @param string $where 置換する文字列
155     * @param array $arrval WHERE 句の要素の配列
156     * @param string $option SQL 文の追加文字列
157     * @return string 置換後の SQL 文
158     */
159    function sfViewWhere($target, $where = "", $arrval = array(), $option = ""){
160
161        $arrWhere = split("[?]", $where);
162        $where_tmp = " WHERE " . $arrWhere[0];
163        for($i = 1; $i < count($arrWhere); $i++){
164            $where_tmp .= SC_Utils_Ex::sfQuoteSmart($arrval[$i - 1]) . $arrWhere[$i];
165        }
166        $arrWhere = $this->getWhereConverter();
167        $arrWhere[$target] = $where_tmp . " " . $option;
168        return $arrWhere[$target];
169    }
170
171    /**
172     * View をインラインビューに変換する.
173     *
174     * @access private
175     * @param string $sql SQL 文
176     * @return string インラインビューに変換した SQL 文
177     */
178    function sfChangeView($sql){
179       
180        $arrViewTmp = $this->viewToSubQuery();
181       
182            // viewのwhereを変換
183        foreach($arrViewTmp as $key => $val){
184            $arrViewTmp[$key] = strtr($arrViewTmp[$key], $this->getWhereConverter());
185        }
186           
187            // viewを変換
188        $changesql = strtr($sql, $arrViewTmp);
189       
190        return $changesql;
191    }
192
193    /**
194     * ILIKE句 を LIKE句へ変換する.
195     *
196     * @access private
197     * @param string $sql SQL文
198     * @return string 変換後の SQL 文
199     */
200    function sfChangeILIKE($sql){
201        $changesql = eregi_replace("(ILIKE )", "LIKE ", $sql);
202        return $changesql;
203    }
204
205    /**
206     * RANDOM() を RAND() に変換する.
207     *
208     * @access private
209     * @param string $sql SQL文
210     * @return string 変換後の SQL 文
211     */
212    function sfChangeRANDOM($sql){
213        $changesql = eregi_replace("( RANDOM)", " RAND", $sql);
214        return $changesql;
215    }
216
217    /**
218     * TRUNC() を TRUNCATE() に変換する.
219     *
220     * @access private
221     * @param string $sql SQL文
222     * @return string 変換後の SQL 文
223     */
224    function sfChangeTrunc($sql){
225        $changesql = eregi_replace("( TRUNC)", " TRUNCATE", $sql);
226        return $changesql;
227    }
228   
229    /**
230     * WHERE 句置換用の配列を返す.
231     *
232     * @access private
233     * @return array WHERE 句置換用の配列
234     */
235    function getWhereConverter() {
236        return array(
237            "&&crscls_where&&" => "",
238            "&&crsprdcls_where&&" =>"",
239            "&&noncls_where&&" => "",
240            "&&allcls_where&&" => "",
241            "&&allclsdtl_where&&" => "",
242            "&&prdcls_where&&" => "",
243            "&&catcnt_where&&" => ""
244        );
245    }
246
247    /**
248     * View をサブクエリに変換するための配列を返す.
249     *
250     * @access private
251     * @return array View をサブクエリに変換するための配列
252     */
253    function viewToSubQuery() {
254        $sql['vw_products_allclass_detail'] =<<< __EOS__
255            (
256                SELECT
257                    dtb_products.product_id,
258                    dtb_products.name,
259                    dtb_products.deliv_fee,
260                    dtb_products.sale_limit,
261                    dtb_products.sale_unlimited,
262                    dtb_products.maker_id,
263                    dtb_products.rank,
264                    dtb_products.status,
265                    dtb_products.product_flag,
266                    dtb_products.point_rate,
267                    dtb_products.comment1,
268                    dtb_products.comment2,
269                    dtb_products.comment3,
270                    dtb_products.comment4,
271                    dtb_products.comment5,
272                    dtb_products.comment6,
273                    dtb_products.note,
274                    dtb_products.file1,
275                    dtb_products.file2,
276                    dtb_products.file3,
277                    dtb_products.file4,
278                    dtb_products.file5,
279                    dtb_products.file6,
280                    dtb_products.main_list_comment,
281                    dtb_products.main_list_image,
282                    dtb_products.main_comment,
283                    dtb_products.main_image,
284                    dtb_products.main_large_image,
285                    dtb_products.sub_title1,
286                    dtb_products.sub_comment1,
287                    dtb_products.sub_image1,
288                    dtb_products.sub_large_image1,
289                    dtb_products.sub_title2,
290                    dtb_products.sub_comment2,
291                    dtb_products.sub_image2,
292                    dtb_products.sub_large_image2,
293                    dtb_products.sub_title3,
294                    dtb_products.sub_comment3,
295                    dtb_products.sub_image3,
296                    dtb_products.sub_large_image3,
297                    dtb_products.sub_title4,
298                    dtb_products.sub_comment4,
299                    dtb_products.sub_image4,
300                    dtb_products.sub_large_image4,
301                    dtb_products.sub_title5,
302                    dtb_products.sub_comment5,
303                    dtb_products.sub_image5,
304                    dtb_products.sub_large_image5,
305                    dtb_products.sub_title6,
306                    dtb_products.sub_comment6,
307                    dtb_products.sub_image6,
308                    dtb_products.sub_large_image6,
309                    dtb_products.del_flg,
310                    dtb_products.creator_id,
311                    dtb_products.create_date,
312                    dtb_products.update_date,
313                    dtb_products.deliv_date_id,
314                    T4.product_code_min,
315                    T4.product_code_max,
316                    T4.price01_min,
317                    T4.price01_max,
318                    T4.price02_min,
319                    T4.price02_max,
320                    T4.stock_min,
321                    T4.stock_max,
322                    T4.stock_unlimited_min,
323                    T4.stock_unlimited_max,
324                    T4.class_count
325                FROM
326                    dtb_products
327                    LEFT JOIN
328                        (
329                            SELECT
330                                product_id,
331                                MIN(product_code) AS product_code_min,
332                                MAX(product_code) AS product_code_max,
333                                MIN(price01) AS price01_min,
334                                MAX(price01) AS price01_max,
335                                MIN(price02) AS price02_min,
336                                MAX(price02) AS price02_max,
337                                MIN(stock) AS stock_min,
338                                MAX(stock) AS stock_max,
339                                MIN(stock_unlimited) AS stock_unlimited_min,
340                                MAX(stock_unlimited) AS stock_unlimited_max,
341                                COUNT(*) as class_count
342                            FROM dtb_products_class
343                            GROUP BY product_id
344                        ) AS T4
345                        ON dtb_products.product_id = T4.product_id
346            )
347__EOS__;
348
349        return array(
350            "vw_cross_class" => '
351                (SELECT T1.class_id AS class_id1, T2.class_id AS class_id2, T1.classcategory_id AS classcategory_id1, T2.classcategory_id AS classcategory_id2, T1.name AS name1, T2.name AS name2, T1.rank AS rank1, T2.rank AS rank2
352                FROM dtb_classcategory AS T1, dtb_classcategory AS T2 ) ',
353
354            "vw_cross_products_class" =>'
355                (SELECT T1.class_id1, T1.class_id2, T1.classcategory_id1, T1.classcategory_id2, T2.product_id,
356                T1.name1, T1.name2, T2.product_code, T2.stock, T2.price01, T2.price02, T1.rank1, T1.rank2
357                FROM (SELECT T1.class_id AS class_id1, T2.class_id AS class_id2, T1.classcategory_id AS classcategory_id1, T2.classcategory_id AS classcategory_id2, T1.name AS name1, T2.name AS name2, T1.rank AS rank1, T2.rank AS rank2
358                FROM dtb_classcategory AS T1, dtb_classcategory AS T2 ) AS T1 LEFT JOIN dtb_products_class AS T2
359                ON T1.classcategory_id1 = T2.classcategory_id1 AND T1.classcategory_id2 = T2.classcategory_id2) ',
360
361            "vw_products_nonclass" => '
362                (
363                    SELECT *
364                    FROM
365                        dtb_products AS T1
366                        LEFT JOIN
367                        (
368                            SELECT
369                                product_id AS product_id_sub,
370                                product_code,
371                                price01,
372                                price02,
373                                stock,
374                                stock_unlimited,
375                                classcategory_id1,
376                                classcategory_id2
377                            FROM dtb_products_class
378                            WHERE
379                                classcategory_id1 = 0
380                                AND classcategory_id2 = 0
381                        ) AS T2
382                        ON T1.product_id = T2.product_id_sub
383                )
384            ',
385
386            "vw_products_allclass" => "
387            (
388                SELECT
389                    alldtl.*,
390                    dtb_category.rank AS category_rank,
391                    T2.category_id,
392                    T2.rank AS product_rank
393                FROM
394                    {$sql['vw_products_allclass_detail']} AS alldtl
395                    LEFT JOIN
396                        dtb_product_categories AS T2
397                        ON alldtl.product_id = T2.product_id
398                    LEFT JOIN
399                        dtb_category
400                        ON T2.category_id = dtb_category.category_id
401            ) ",
402
403            "vw_products_allclass_detail" => $sql['vw_products_allclass_detail'],
404
405            "vw_product_class" => '
406                (SELECT * FROM
407                (SELECT T3.product_class_id, T3.product_id AS product_id_sub, classcategory_id1, classcategory_id2,
408                T3.rank AS rank1, T4.rank AS rank2, T3.class_id AS class_id1, T4.class_id AS class_id2,
409                stock, price01, price02, stock_unlimited, product_code
410                FROM ( SELECT
411                        T1.product_class_id,
412                        T1.product_id,
413                        classcategory_id1,
414                        classcategory_id2,
415                        T2.rank,
416                        T2.class_id,
417                        stock,
418                        price01,
419                        price02,
420                        stock_unlimited,
421                        product_code
422                 FROM (dtb_products_class AS T1 LEFT JOIN dtb_classcategory AS T2
423                ON T1.classcategory_id1 = T2.classcategory_id))
424                AS T3 LEFT JOIN dtb_classcategory AS T4
425                ON T3.classcategory_id2 = T4.classcategory_id) AS T5 LEFT JOIN dtb_products AS T6
426                ON product_id_sub = T6.product_id) ',
427
428            "vw_category_count" => '
429                (SELECT T1.category_id, T1.category_name, T1.parent_category_id, T1.level, T1.rank, T2.product_count
430                FROM dtb_category AS T1 LEFT JOIN dtb_category_total_count AS T2
431                ON T1.category_id = T2.category_id) '
432        );
433    }
434}
435?>
Note: See TracBrowser for help on using the repository browser.