Source for file SC_DB_DBFactory_MYSQL.php
Documentation is available at SC_DB_DBFactory_MYSQL.php
* This file is part of EC-CUBE
* Copyright(c) 2000-2010 LOCKON CO.,LTD. All Rights Reserved.
* http://www.lockon.co.jp/
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
require_once(CLASS_PATH . "db/SC_DB_DBFactory.php");
* 必ず SC_DB_DBFactory クラスを経由してインスタンス化する.
* また, SC_DB_DBFactory クラスの関数を必ずオーバーライドしている必要がある.
* @author LOCKON CO.,LTD.
* @version $Id:SC_DB_DBFactory_MYSQL.php 15267 2007-08-09 12:31:52Z nanasess $
* @param string $dsn データソース名
* @return string データベースのバージョン
list ($db_type) = split(":", $dsn);
$val = $objQuery->getOne("select version()");
* @param string $sql SQL 文
* @return string MySQL 用に置換した SQL 文
$sql = $this->sfChangeView($sql);
$sql = $this->sfChangeILIKE($sql);
$sql = $this->sfChangeRANDOM($sql);
$sql = $this->sfChangeTrunc($sql);
$arrRet = $objQuery->getAll("SHOW VARIABLES LIKE 'char%'");
* テーブルの存在チェックを行う SQL 文を返す.
* @return string テーブルの存在チェックを行う SQL 文
return "SHOW TABLE STATUS LIKE ?";
* @param string $index_name インデックス名
* @param string $table_name テーブル名
* @return array インデックスの検索結果の配列
$objQuery = new SC_Query("", true, true);
return $objQuery->getAll("SHOW INDEX FROM " . $table_name . " WHERE Key_name = ?",
* @param string $index_name インデックス名
* @param string $table_name テーブル名
* @param string $col_name カラム名
* @param integer $length 作成するインデックスのバイト長
$objQuery = new SC_Query($dsn, true, true);
$objQuery->query("CREATE INDEX ? ON ? (?(?))", array($index_name, $table_name, $col_name, $length));
* @param string $table_name テーブル名
* @return array テーブルのカラム一覧の配列
$sql = "SHOW COLUMNS FROM " . $table_name;
$arrColList = $objQuery->getAll($sql);
$arrColList = SC_Utils_Ex::sfswaparray($arrColList);
return $arrColList["Field"];
* @param string $expression 検索文字列
$sql = "SHOW TABLES LIKE ?";
$arrColList = $objQuery->getAll($sql, array("%" . $expression . "%"));
$arrColList = SC_Utils_Ex::sfswaparray($arrColList, false);
* @param string $target 置換対象の文字列
* @param string $where 置換する文字列
* @param array $arrval WHERE 句の要素の配列
* @param string $option SQL 文の追加文字列
* @return string 置換後の SQL 文
function sfViewWhere($target, $where = "", $arrval = array(), $option = ""){
$arrWhere = split("[?]", $where);
$where_tmp = " WHERE " . $arrWhere[0];
for($i = 1; $i < count($arrWhere); $i++ ){
$where_tmp .= SC_Utils_Ex::sfQuoteSmart($arrval[$i - 1]) . $arrWhere[$i];
$arrWhere = $this->getWhereConverter();
$arrWhere[$target] = $where_tmp . " " . $option;
return $arrWhere[$target];
* SQL の中の View の存在をチェックする.
* @param string $sql SQL 文
* @return bool Viewが存在しない場合 false
function sfInArray($sql){
$arrView = $this->viewToSubQuery();
foreach($arrView as $key => $val){
$this->sfInArray($changesql);
* @param string $sql SQL 文
* @return string インラインビューに変換した SQL 文
function sfChangeView($sql){
$arrViewTmp = $this->viewToSubQuery();
foreach($arrViewTmp as $key => $val){
$arrViewTmp[$key] = strtr($arrViewTmp[$key], $this->getWhereConverter());
$changesql = strtr($sql, $arrViewTmp);
* @param string $sql SQL文
* @return string 変換後の SQL 文
function sfChangeILIKE($sql){
* RANDOM() を RAND() に変換する.
* @param string $sql SQL文
* @return string 変換後の SQL 文
function sfChangeRANDOM($sql){
* TRUNC() を TRUNCATE() に変換する.
* @param string $sql SQL文
* @return string 変換後の SQL 文
function sfChangeTrunc($sql){
* @return array WHERE 句置換用の配列
function getWhereConverter() {
"&&crscls_where&&" => "",
"&&crsprdcls_where&&" => "",
"&&noncls_where&&" => "",
"&&allcls_where&&" => "",
"&&allclsdtl_where&&" => "",
"&&prdcls_where&&" => "",
* View をサブクエリに変換するための配列を返す.
* @return array View をサブクエリに変換するための配列
function viewToSubQuery() {
$sql['vw_products_allclass_detail'] =<<< __EOS__
dtb_products.sale_unlimited,
dtb_products.product_flag,
dtb_products.main_list_comment,
dtb_products.main_list_image,
dtb_products.main_comment,
dtb_products.main_large_image,
dtb_products.sub_comment1,
dtb_products.sub_large_image1,
dtb_products.sub_comment2,
dtb_products.sub_large_image2,
dtb_products.sub_comment3,
dtb_products.sub_large_image3,
dtb_products.sub_comment4,
dtb_products.sub_large_image4,
dtb_products.sub_comment5,
dtb_products.sub_large_image5,
dtb_products.sub_comment6,
dtb_products.sub_large_image6,
dtb_products.create_date,
dtb_products.update_date,
dtb_products.deliv_date_id,
MIN(product_code) AS product_code_min,
MAX(product_code) AS product_code_max,
MIN(price01) AS price01_min,
MAX(price01) AS price01_max,
MIN(price02) AS price02_min,
MAX(price02) AS price02_max,
MIN(stock_unlimited) AS stock_unlimited_min,
MAX(stock_unlimited) AS stock_unlimited_max,
ON dtb_products.product_id = T4.product_id
(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
FROM dtb_classcategory AS T1, dtb_classcategory AS T2 ) ',
"vw_cross_products_class" => '
(SELECT T1.class_id1, T1.class_id2, T1.classcategory_id1, T1.classcategory_id2, T2.product_id,
T1.name1, T1.name2, T2.product_code, T2.stock, T2.price01, T2.price02, T1.rank1, T1.rank2
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
FROM dtb_classcategory AS T1, dtb_classcategory AS T2 ) AS T1 LEFT JOIN dtb_products_class AS T2
ON T1.classcategory_id1 = T2.classcategory_id1 AND T1.classcategory_id2 = T2.classcategory_id2) ',
"vw_products_nonclass" => '
FROM (SELECT * FROM dtb_products &&noncls_where&&) AS T1 LEFT JOIN
product_id AS product_id_sub,
FROM dtb_products_class WHERE classcategory_id1 = 0 AND classcategory_id2 = 0)
ON T1.product_id = T2.product_id_sub) ',
"vw_products_allclass" => "
dtb_category.rank AS category_rank,
{$sql['vw_products_allclass_detail']} AS alldtl
dtb_product_categories AS T2
ON alldtl.product_id = T2.product_id
ON T2.category_id = dtb_category.category_id
"vw_products_allclass_detail" => $sql['vw_products_allclass_detail'],
(SELECT T3.product_class_id, T3.product_id AS product_id_sub, classcategory_id1, classcategory_id2,
T3.rank AS rank1, T4.rank AS rank2, T3.class_id AS class_id1, T4.class_id AS class_id2,
stock, price01, price02, stock_unlimited, product_code
FROM (dtb_products_class AS T1 LEFT JOIN dtb_classcategory AS T2
ON T1.classcategory_id1 = T2.classcategory_id))
AS T3 LEFT JOIN dtb_classcategory AS T4
ON T3.classcategory_id2 = T4.classcategory_id) AS T5 LEFT JOIN dtb_products AS T6
ON product_id_sub = T6.product_id) ',
(SELECT T1.category_id, T1.category_name, T1.parent_category_id, T1.level, T1.rank, T2.product_count
FROM dtb_category AS T1 LEFT JOIN dtb_category_total_count AS T2
ON T1.category_id = T2.category_id) '
Documentation generated on Fri, 24 Feb 2012 14:00:05 +0900 by Seasoft
|