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

Revision 18789, 8.3 KB checked in by nanasess, 14 years ago (diff)

DB_TYPE で条件分岐している箇所の抽象化(#801)

  • DB_TYPE で条件分岐している箇所の修正
  • SC_DB_DBFactory に関数を追加
    • getOrderYesterdaySql()
    • getOrderMonthSql()
    • getReviewYesterdaySql()
    • getSendHistoryWhereStartdateSql()
    • concatColumn()
  • SC_Utils::sfManualEscape() の実装を SC_Query::quote() に変更
  • 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
25// {{{ requires
26require_once(CLASS_PATH . "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::getSingletonInstance();
49        $val = $objQuery->getOne("select version()");
50        $arrLine = split(" " , $val);
51        return $arrLine[0] . " " . $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 $table_name 存在チェックを行うテーブル名
71     * @return string テーブルの存在チェックを行う SQL 文
72     */
73    function getTableExistsSql($table_name) {
74        $objQuery =& SC_Query::getSingletonInstance();
75        return "  SELECT relname "
76             . "    FROM pg_class "
77             . "   WHERE (relkind = 'r' OR relkind = 'v') "
78             . "     AND relname = " . $objQuery->quote($table_name)
79             . "GROUP BY relname";
80    }
81
82    /**
83     * 昨日の売上高・売上件数を算出する SQL を返す.
84     *
85     * @param string $method SUM または COUNT
86     * @return string 昨日の売上高・売上件数を算出する SQL
87     */
88    function getOrderYesterdaySql($method) {
89        return "SELECT ".$method."(total) FROM dtb_order "
90              . "WHERE del_flg = 0 "
91                . "AND to_char(create_date,'YYYY/MM/DD') = to_char(now() - interval '1 days','YYYY/MM/DD') "
92                . "AND status <> " . ORDER_CANCEL;
93    }
94
95    /**
96     * 当月の売上高・売上件数を算出する SQL を返す.
97     *
98     * @param string $method SUM または COUNT
99     * @return string 当月の売上高・売上件数を算出する SQL
100     */
101    function getOrderMonthSql($method) {
102        return "SELECT ".$method."(total) FROM dtb_order "
103              . "WHERE del_flg = 0 "
104                . "AND to_char(create_date,'YYYY/MM') = ? "
105                . "AND to_char(create_date,'YYYY/MM/DD') <> to_char(now(),'YYYY/MM/DD') "
106                . "AND status <> " . ORDER_CANCEL;
107    }
108
109    /**
110     * 昨日のレビュー書き込み件数を算出する SQL を返す.
111     *
112     * @return string 昨日のレビュー書き込み件数を算出する SQL
113     */
114    function getReviewYesterdaySql() {
115        return "SELECT COUNT(*) FROM dtb_review AS A "
116          . "LEFT JOIN dtb_products AS B "
117                 . "ON A.product_id = B.product_id "
118              . "WHERE A.del_flg=0 "
119                . "AND B.del_flg = 0 "
120                . "AND to_char(A.create_date, 'YYYY/MM/DD') = to_char(now() - interval '1 days','YYYY/MM/DD') "
121                . "AND to_char(A.create_date,'YYYY/MM/DD') != to_char(now(),'YYYY/MM/DD')";
122    }
123
124    /**
125     * メール送信履歴の start_date の検索条件の SQL を返す.
126     *
127     * @return string 検索条件の SQL
128     */
129    function getSendHistoryWhereStartdateSql() {
130        return "start_date BETWEEN current_timestamp + '- 5 minutes' AND current_timestamp + '5 minutes'";
131    }
132
133    /**
134     * 文字列連結を行う.
135     *
136     * @param array $columns 連結を行うカラム名
137     * @return string 連結後の SQL 文
138     */
139    function concatColumn($columns) {
140        $sql = "";
141        $i = 0;
142        $total = count($columns);
143        foreach ($columns as $column) {
144            $sql .= $column;
145            if ($i < $total -1) {
146                $sql .= " || ";
147            }
148            $i++;
149        }
150        return $sql;
151    }
152
153    /**
154     * インデックスの検索結果を配列で返す.
155     *
156     * @param string $index_name インデックス名
157     * @param string $table_name テーブル名(PostgreSQL では使用しない)
158     * @return array インデックスの検索結果の配列
159     */
160    function getTableIndex($index_name, $table_name = "") {
161        $objQuery =& SC_Query::getSingletonInstance();
162        return $objQuery->getAll("SELECT relname FROM pg_class WHERE relname = ?",
163                                 array($index_name));
164    }
165
166    /**
167     * インデックスを作成する.
168     *
169     * @param string $index_name インデックス名
170     * @param string $table_name テーブル名
171     * @param string $col_name カラム名
172     * @param integer $length 作成するインデックスのバイト長
173     * @return void
174     */
175    function createTableIndex($index_name, $table_name, $col_name, $length = 0) {
176        $objQuery =& SC_Query::getSingletonInstance();
177        $objQuery->query("CREATE INDEX ? ON ? (?)", array($index_name, $table_name, $col_name));
178    }
179
180    /**
181     * テーブルのカラム一覧を取得する.
182     *
183     * @param string $table_name テーブル名
184     * @return array テーブルのカラム一覧の配列
185     */
186    function sfGetColumnList($table_name) {
187        $objQuery =& SC_Query::getSingletonInstance();
188        $sql = "  SELECT a.attname "
189             . "    FROM pg_class c, pg_attribute a "
190             . "   WHERE c.relname=? "
191             . "     AND c.oid=a.attrelid "
192             . "     AND a.attnum > 0 "
193             . "     AND not a.attname "
194             . "    LIKE '........pg.dropped.%........' "
195             . "ORDER BY a.attnum";
196        $arrColList = $objQuery->getAll($sql, array($table_name));
197        $arrColList = SC_Utils_Ex::sfswaparray($arrColList);
198        return $arrColList["attname"];
199    }
200
201    /**
202     * テーブルを検索する.
203     *
204     * 引数に部分一致するテーブル名を配列で返す.
205     *
206     * @param string $expression 検索文字列
207     * @return array テーブル名の配列
208     */
209    function findTableNames($expression = "") {
210        $objQuery =& SC_Query::getSingletonInstance();
211        $sql = "   SELECT c.relname AS name, "
212            .  "     CASE c.relkind "
213            .  "     WHEN 'r' THEN 'table' "
214            .  "     WHEN 'v' THEN 'view' END AS type "
215            .  "     FROM pg_catalog.pg_class c "
216            .  "LEFT JOIN pg_catalog.pg_namespace n "
217            .  "       ON n.oid = c.relnamespace "
218            .  "    WHERE c.relkind IN ('r','v') "
219            .  "      AND n.nspname NOT IN ('pg_catalog', 'pg_toast') "
220            .  "      AND pg_catalog.pg_table_is_visible(c.oid) "
221            .  "      AND c.relname LIKE ?"
222            .  " ORDER BY 1,2;";
223        $arrColList = $objQuery->getAll($sql, array("%" . $expression . "%"));
224        $arrColList = SC_Utils_Ex::sfswaparray($arrColList, false);
225        return $arrColList[0];
226    }
227   
228   
229    /**
230     * 文字コード情報を取得する
231     *
232     * @return array 文字コード情報
233     */
234     function getCharSet() {
235        // 未実装
236        return array();
237     }
238}
239?>
Note: See TracBrowser for help on using the repository browser.