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

Revision 21420, 8.4 KB checked in by Seasoft, 12 years ago (diff)

#1613 (ソース整形・ソースコメントの改善)

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