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

Revision 20538, 8.9 KB checked in by Seasoft, 13 years ago (diff)

#627(ソース整形・ソースコメントの改善)
#628(未使用処理・定義などの削除)

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • 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
25// {{{ requires
26require_once CLASS_REALDIR . 'db/SC_DB_DBFactory.php';
27
28/**
29 * PostgreSQL 固有の処理をするクラス.
30 *
31 * このクラスを直接インスタンス化しないこと.
32 * 必ず SC_DB_DBFactory クラスを経由してインスタンス化する.
33 * また, SC_DB_DBFactory クラスの関数を必ずオーバーライドしている必要がある.
34 *
35 * @package DB
36 * @author LOCKON CO.,LTD.
37 * @version $Id:SC_DB_DBFactory_PGSQL.php 15532 2007-08-31 14:39:46Z nanasess $
38 */
39class SC_DB_DBFactory_PGSQL extends SC_DB_DBFactory {
40
41    /**
42     * DBのバージョンを取得する.
43     *
44     * @param string $dsn データソース名
45     * @return string データベースのバージョン
46     */
47    function sfGetDBVersion($dsn = "") {
48        $objQuery =& SC_Query_Ex::getSingletonInstance();
49        $val = $objQuery->getOne("select version()");
50        $arrLine = explode(" " , $val);
51        return $arrLine[0] . " " . str_replace(",", "", $arrLine[1]);
52    }
53
54    /**
55     * MySQL 用の SQL 文に変更する.
56     *
57     * DB_TYPE が PostgreSQL の場合は何もしない
58     *
59     * @access private
60     * @param string $sql SQL 文
61     * @return string MySQL 用に置換した SQL 文
62     */
63    function sfChangeMySQL($sql){
64        return $sql;
65    }
66
67    /**
68     * 昨日の売上高・売上件数を算出する SQL を返す.
69     *
70     * @param string $method SUM または COUNT
71     * @return string 昨日の売上高・売上件数を算出する SQL
72     */
73    function getOrderYesterdaySql($method) {
74        return "SELECT ".$method."(total) FROM dtb_order "
75              . "WHERE del_flg = 0 "
76                . "AND to_char(create_date,'YYYY/MM/DD') = to_char(now() - interval '1 days','YYYY/MM/DD') "
77                . "AND status <> " . ORDER_CANCEL;
78    }
79
80    /**
81     * 当月の売上高・売上件数を算出する SQL を返す.
82     *
83     * @param string $method SUM または COUNT
84     * @return string 当月の売上高・売上件数を算出する SQL
85     */
86    function getOrderMonthSql($method) {
87        return "SELECT ".$method."(total) FROM dtb_order "
88              . "WHERE del_flg = 0 "
89                . "AND to_char(create_date,'YYYY/MM') = ? "
90                . "AND to_char(create_date,'YYYY/MM/DD') <> to_char(now(),'YYYY/MM/DD') "
91                . "AND status <> " . ORDER_CANCEL;
92    }
93
94    /**
95     * 昨日のレビュー書き込み件数を算出する SQL を返す.
96     *
97     * @return string 昨日のレビュー書き込み件数を算出する SQL
98     */
99    function getReviewYesterdaySql() {
100        return "SELECT COUNT(*) FROM dtb_review AS A "
101          . "LEFT JOIN dtb_products AS B "
102                 . "ON A.product_id = B.product_id "
103              . "WHERE A.del_flg=0 "
104                . "AND B.del_flg = 0 "
105                . "AND to_char(A.create_date, 'YYYY/MM/DD') = to_char(now() - interval '1 days','YYYY/MM/DD') "
106                . "AND to_char(A.create_date,'YYYY/MM/DD') != to_char(now(),'YYYY/MM/DD')";
107    }
108
109    /**
110     * メール送信履歴の start_date の検索条件の SQL を返す.
111     *
112     * @return string 検索条件の SQL
113     */
114    function getSendHistoryWhereStartdateSql() {
115        return "start_date BETWEEN current_timestamp + '- 5 minutes' AND current_timestamp + '5 minutes'";
116    }
117
118    /**
119     * ダウンロード販売の検索条件の SQL を返す.
120     *
121     * @param string $dtb_order_alias
122     * @return string 検索条件の SQL
123     */
124    function getDownloadableDaysWhereSql($dtb_order_alias = 'dtb_order') {
125        $baseinfo = SC_Helper_DB_Ex::sfGetBasisData();
126        //downloadable_daysにNULLが入っている場合(無期限ダウンロード可能時)もあるので、NULLの場合は0日に補正
127        $downloadable_days = $baseinfo['downloadable_days'];
128        if($downloadable_days ==null || $downloadable_days == "")$downloadable_days=0;
129        return "(SELECT CASE WHEN (SELECT d1.downloadable_days_unlimited FROM dtb_baseinfo d1) = 1 AND " . $dtb_order_alias . ".payment_date IS NOT NULL THEN 1 WHEN DATE(NOW()) <= DATE(" . $dtb_order_alias . ".payment_date + '". $downloadable_days ." days') THEN 1 ELSE 0 END)";
130    }
131
132    /**
133     * 売上集計の期間別集計のSQLを返す
134     *
135     * @param mixed $type
136     * @return string 検索条件のSQL
137     */
138    function getOrderTotalDaysWhereSql($type) {
139        switch($type){
140        case 'month':
141            $format = 'MM';
142            break;
143        case 'year':
144            $format = 'YYYY';
145            break;
146        case 'wday':
147            $format = 'Dy';
148            break;
149        case 'hour':
150            $format = 'HH24';
151            break;
152        default:
153            $format = 'YYYY-MM-DD';
154            break;
155        }
156
157        return "to_char(create_date, '".$format."') AS str_date,
158            COUNT(order_id) AS total_order,
159            SUM(CASE WHEN order_sex = 1 THEN 1 ELSE 0 END) AS men,
160            SUM(CASE WHEN order_sex = 2 THEN 1 ELSE 0 END) AS women,
161            SUM(CASE WHEN customer_id <> 0 AND order_sex = 1 THEN 1 ELSE 0 END) AS men_member,
162            SUM(CASE WHEN customer_id <> 0 AND order_sex = 2 THEN 1 ELSE 0 END) AS women_member,
163            SUM(CASE WHEN customer_id = 0 AND order_sex = 1 THEN 1 ELSE 0 END) AS men_nonmember,
164            SUM(CASE WHEN customer_id = 0 AND order_sex = 2 THEN 1 ELSE 0 END) AS women_nonmember,
165            SUM(total) AS total,
166            AVG(total) AS total_average";
167    }
168
169
170    /**
171     * 文字列連結を行う.
172     *
173     * @param array $columns 連結を行うカラム名
174     * @return string 連結後の SQL 文
175     */
176    function concatColumn($columns) {
177        $sql = "";
178        $i = 0;
179        $total = count($columns);
180        foreach ($columns as $column) {
181            $sql .= $column;
182            if ($i < $total -1) {
183                $sql .= " || ";
184            }
185            $i++;
186        }
187        return $sql;
188    }
189
190    /**
191     * テーブルのカラム一覧を取得する.
192     *
193     * @deprecated SC_Query::listTableFields() を使用してください
194     * @param string $table_name テーブル名
195     * @return array テーブルのカラム一覧の配列
196     */
197    function sfGetColumnList($table_name) {
198        $objQuery =& SC_Query_Ex::getSingletonInstance();
199        $sql = "  SELECT a.attname "
200             . "    FROM pg_class c, pg_attribute a "
201             . "   WHERE c.relname=? "
202             . "     AND c.oid=a.attrelid "
203             . "     AND a.attnum > 0 "
204             . "     AND not a.attname "
205             . "    LIKE '........pg.dropped.%........' "
206             . "ORDER BY a.attnum";
207        $arrColList = $objQuery->getAll($sql, array($table_name));
208        $arrColList = SC_Utils_Ex::sfswaparray($arrColList);
209        return $arrColList['attname'];
210    }
211
212    /**
213     * テーブルを検索する.
214     *
215     * 引数に部分一致するテーブル名を配列で返す.
216     *
217     * @deprecated SC_Query::listTables() を使用してください
218     * @param string $expression 検索文字列
219     * @return array テーブル名の配列
220     */
221    function findTableNames($expression = "") {
222        $objQuery =& SC_Query_Ex::getSingletonInstance();
223        $sql = "   SELECT c.relname AS name, "
224            .  "     CASE c.relkind "
225            .  "     WHEN 'r' THEN 'table' "
226            .  "     WHEN 'v' THEN 'view' END AS type "
227            .  "     FROM pg_catalog.pg_class c "
228            .  "LEFT JOIN pg_catalog.pg_namespace n "
229            .  "       ON n.oid = c.relnamespace "
230            .  "    WHERE c.relkind IN ('r','v') "
231            .  "      AND n.nspname NOT IN ('pg_catalog', 'pg_toast') "
232            .  "      AND pg_catalog.pg_table_is_visible(c.oid) "
233            .  "      AND c.relname LIKE ?"
234            .  " ORDER BY 1,2;";
235        $arrColList = $objQuery->getAll($sql, array("%" . $expression . "%"));
236        $arrColList = SC_Utils_Ex::sfswaparray($arrColList, false);
237        return $arrColList[0];
238    }
239
240    /**
241     * 文字コード情報を取得する
242     *
243     * @return array 文字コード情報
244     */
245     function getCharSet() {
246        // 未実装
247        return array();
248     }
249}
250?>
Note: See TracBrowser for help on using the repository browser.