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

Revision 18777, 17.8 KB checked in by eccuore, 14 years ago (diff)

#792(ダウンロード販売機能) 機能追加

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